博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 3785 寻找大富翁
阅读量:6227 次
发布时间:2019-06-21

本文共 1548 字,大约阅读时间需要 5 分钟。

寻找大富翁

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)

Total Submission(s): 6716    Accepted Submission(s): 2492

Problem Description
浙江桐乡乌镇共有n个人,请找出该镇上的前m个大富翁.
 

 

Input
输入包含多组测试用例.
每个用例首先包含2个整数n(0<n<=100000)和m(0<m<=10),其中: n为镇上的人数,m为需要找出的大富翁数, 接下来一行输入镇上n个人的财富值.
n和m同时为0时表示输入结束.
 

 

Output
请输出乌镇前m个大富翁的财产数,财产多的排前面,如果大富翁不足m个,则全部输出,每组输出占一行.
 

 

Sample Input
3 1
2 5 -1
5 3
1 2 3 4 5
0 0
 
Sample Output
5
5 4 3
Source
 题目链接:
分析:这题很坑呐!用C++输入输出会超时,此题应选用scanf输入!开始尝试着倒序输出,超时!虽然要求前m的大富翁,但负数就不算是大富翁了,这时就应该全部输出,这个问题没有注意到,继续WA!此题还要注意空格的输入输出,不然肯定又PE了!
以下给出AC代码:
1 #include 
2 using namespace std; 3 int main() 4 { 5 int a[100005]; 6 int n,m,i,j,k; 7 while(scanf("%d%d",&n,&m)&&m&&n) 8 { 9 k=0;10 for(i=0;i
n)14 {15 for(i=n-1;i>=0;i--)16 {17 printf("%d",a[n]);18 if(i!=0)19 printf(" ");20 }21 printf("\n");22 continue;23 }24 for(i=n-1;i>=n-m;i--)25 {26 if(a[i]<0)27 {28 j=i;29 k=1;30 break;31 }32 printf("%d",a[i]);33 if(i!=n-m)34 printf(" ");35 }36 if(k!=0)37 {38 for(i=j;i>=0;i++)39 {40 printf("%d",a[i]);41 if(i!=0)42 printf(" ");43 }44 }45 printf("\n");46 }47 return 0;48 }

 

转载地址:http://gsfna.baihongyu.com/

你可能感兴趣的文章
20170322Linux
查看>>
NOIp 2014 #1 生活大爆炸版石头剪刀布 Label:模拟
查看>>
判断相同树或者对称树
查看>>
foundation学习
查看>>
oracle之 获取建表ddl语句
查看>>
oracle 之 安装10.2.0.1 且 升级到 10.2.0.4
查看>>
Java培训学习笔记(四):简单小总结
查看>>
NYOJ467中缀式变后缀式
查看>>
视图层 表格里面的 的超链接
查看>>
Linux里面非常重要的目录
查看>>
angular-seed — AngularJS种子项目
查看>>
开发人员准确理解技术需求:用户想得与说的不一样
查看>>
OpenCV 颜色空间转换参数CV_BGR2GRAY改变
查看>>
Allegro PCB Design GXL (legacy) 从dxf文件中导入板框
查看>>
手撸系列之——ORM(对象关系映射)
查看>>
iOS - OC RunLoop 运行循环/消息循环
查看>>
php smarty使用..
查看>>
FLV文件格式解析
查看>>
将Sqlserver2012Express的mdf文件同步到SqlServer2008
查看>>
10条影响CSS渲染速度的写法与建议(摘抄HTML5中国)
查看>>