鱼C论坛

 找回密码
 立即注册
查看: 2805|回复: 12

[已解决]求大佬讲解题目

[复制链接]
发表于 2022-12-28 18:49:45 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
虽然我已经很努力的在解这道题了
但是还是束手无策
有鱼油能帮忙讲解一下吗:
        https://www.luogu.com.cn/problem/P7072
最佳答案
2022-12-28 23:19:24
以下是我的代码。在大佬面前我不敢说我写的好
(其实我本来就写的不好)
主要思路就是对每次出成绩都进行分析。我想也不用再做注明了吧
还望大佬们给出建议,谢谢!
忘了说了,我用的C语言。

  1. #include <stdio.h>
  2. #include <math.h>

  3. int max(int a,int b)
  4. {
  5.         return a>b?a:b;
  6. }

  7. int pn(int p,int w)
  8. {
  9.         return max(1,floor((double)p*w/100));
  10. }

  11. int main()
  12. {
  13.         int n,w,count,i=0,j=0,k=0,m,x;
  14.         scanf("%d",&n);
  15.         scanf("%d",&w);
  16.         int a[n],b[n];
  17.         for(count=0;count<n;count++)
  18.         {
  19.                 scanf("%d",&a[count]);
  20.                 getchar();
  21.         }
  22.         for(count=1;count<=n;count++)
  23.         {
  24.                 for(m=0;m<count;m++)
  25.                 {
  26.                         b[m]=a[m];
  27.                 }
  28.                 for(;m<n;m++)
  29.                 {
  30.                         b[m]=0;
  31.                 }
  32.                 for(i=0;i<n;i++)
  33.                 {
  34.                         for(j=i+1;j<n;j++)
  35.                         {
  36.                                 if(b[i]<b[j])
  37.                                 {
  38.                                         k=b[i];
  39.                                         b[i]=b[j];
  40.                                         b[j]=k;
  41.                                 }
  42.                         }
  43.                 }
  44.                 printf("%d ",b[pn(count,w)-1]);
  45.         }
  46.        
  47.         return 0;
  48. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-12-28 20:53:11 | 显示全部楼层
我觉得你可以先理一下思路。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-12-28 20:53:57 | 显示全部楼层
我想到了爆算不知道你是否接受呢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-12-28 21:15:02 | 显示全部楼层
额外减小 发表于 2022-12-28 20:53
我想到了爆算不知道你是否接受呢

额,时间限制考虑一下
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-12-28 22:56:19 | 显示全部楼层
本帖最后由 额外减小 于 2022-12-28 22:59 编辑

啊啊啊啊啊啊啊啊啊
大佬,我成功了!
你想看我写的源码吗?
你现在用的是什么语言?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-12-28 23:19:24 | 显示全部楼层    本楼为最佳答案   
以下是我的代码。在大佬面前我不敢说我写的好
(其实我本来就写的不好)
主要思路就是对每次出成绩都进行分析。我想也不用再做注明了吧
还望大佬们给出建议,谢谢!
忘了说了,我用的C语言。

  1. #include <stdio.h>
  2. #include <math.h>

  3. int max(int a,int b)
  4. {
  5.         return a>b?a:b;
  6. }

  7. int pn(int p,int w)
  8. {
  9.         return max(1,floor((double)p*w/100));
  10. }

  11. int main()
  12. {
  13.         int n,w,count,i=0,j=0,k=0,m,x;
  14.         scanf("%d",&n);
  15.         scanf("%d",&w);
  16.         int a[n],b[n];
  17.         for(count=0;count<n;count++)
  18.         {
  19.                 scanf("%d",&a[count]);
  20.                 getchar();
  21.         }
  22.         for(count=1;count<=n;count++)
  23.         {
  24.                 for(m=0;m<count;m++)
  25.                 {
  26.                         b[m]=a[m];
  27.                 }
  28.                 for(;m<n;m++)
  29.                 {
  30.                         b[m]=0;
  31.                 }
  32.                 for(i=0;i<n;i++)
  33.                 {
  34.                         for(j=i+1;j<n;j++)
  35.                         {
  36.                                 if(b[i]<b[j])
  37.                                 {
  38.                                         k=b[i];
  39.                                         b[i]=b[j];
  40.                                         b[j]=k;
  41.                                 }
  42.                         }
  43.                 }
  44.                 printf("%d ",b[pn(count,w)-1]);
  45.         }
  46.        
  47.         return 0;
  48. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-12-29 04:46:29 | 显示全部楼层
额外减小 发表于 2022-12-28 23:19
以下是我的代码。在大佬面前我不敢说我写的好
(其实我本来就写的不好)
主要思路就是对每次出成绩都进行 ...

谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-12-29 06:32:12 | 显示全部楼层
额外减小 发表于 2022-12-28 23:19
以下是我的代码。在大佬面前我不敢说我写的好
(其实我本来就写的不好)
主要思路就是对每次出成绩都进行 ...

虽然我用c++,但c++与c差不多,稍稍改动就行了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-12-29 09:57:26 | 显示全部楼层
本帖最后由 jhq999 于 2022-12-29 10:00 编辑
  1. #include <stdio.h>

  2. int main()
  3. {
  4.     int n,w,count,i,j,k,ach;
  5.     scanf("%d%d",&n,&w);
  6.     int s[601]={0};
  7.     for(i=1;i<=n;i+=1)
  8.     {
  9.         scanf("%d",&ach);
  10.         s[ach]+=1;
  11.         count=i*w;
  12.         count=count/100==0?1:count/100;
  13.         for(j=600,k=0;k<count;j-=1)
  14.         {
  15.             if(s[j])
  16.             {
  17.                 k+=s[j];
  18.             }
  19.         }
  20.         printf("%d ",j+1);

  21.     }

  22.     return 0;
  23. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2022-12-29 13:43:41 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-12-29 14:09:01 | 显示全部楼层

大佬,请问您可以讲讲这里面的逻辑思路吗?我看不太懂。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-12-29 15:01:35 | 显示全部楼层
本帖最后由 jhq999 于 2022-12-29 15:04 编辑
额外减小 发表于 2022-12-29 14:09
大佬,请问您可以讲讲这里面的逻辑思路吗?我看不太懂。


你去洛谷看原题了吗?上面分数限制是0到600;所以第一时间想到统计英文26个字母那个体型;
然后根据得出的取名次的范围,从大到小相加,条件是小于名次范围,否则退出循环,这时已经是范围最小值了,也不用考虑什么并列;
也不用排序,属于用空间换时间

评分

参与人数 1鱼币 +1 收起 理由
额外减小 + 1 谢谢大佬^_^

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2023-1-2 23:22:09 | 显示全部楼层
向大佬学习
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-22 23:51

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表