排序
来源:互联网 发布:sql server 2008 免费 编辑:程序博客网 时间:2024/04/30 21:48
排序
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 60405 Accepted Submission(s): 17864
Problem Description
输入一行数字,如果我们把这行数字中的‘5’都看成空格,那么就得到一行用空格分割的若干非负整数(可能有些整数以‘0’开头,这些头部的‘0’应该被忽略掉,除非这个整数就是由若干个‘0’组成的,这时这个整数就是0)。
你的任务是:对这些分割得到的整数,依从小到大的顺序排序输出。
你的任务是:对这些分割得到的整数,依从小到大的顺序排序输出。
Input
输入包含多组测试用例,每组输入数据只有一行数字(数字之间没有空格),这行数字的长度不大于1000。
输入数据保证:分割得到的非负整数不会大于100000000;输入数据不可能全由‘5’组成。
输入数据保证:分割得到的非负整数不会大于100000000;输入数据不可能全由‘5’组成。
Output
对于每个测试用例,输出分割得到的整数排序的结果,相邻的两个整数之间用一个空格分开,每组输出占一行。
Sample Input
0051231232050775
Sample Output
0 77 12312320
#include <algorithm>#include <cstdio>#include <queue>#include <cstring>using namespace std;int main(){ char str[1001]; int s,a[1001],l; while(~scanf("%s",str)) { l=s=0; int len=strlen(str); int i=0; while(str[i]=='5') i++; for(i;i<len;i++) { if(str[i]=='5'&&str[i+1]=='5') continue; if(str[i]!='5') { s=s*10+(str[i]-48); } else { a[l++]=s; s=0; } } if(str[len-1]!='5') a[l++]=s; sort(a,a+l); for(i=0;i<l-1;i++) printf("%d ",a[i]); printf("%d\n",a[l-1]); } return 0;}
阅读全文
0 0
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 排序
- 使用Aspose.Cell控件实现Excel高难度报表的生成(三)
- input属性disabled和readonly的区别
- C#自带的事件
- 区别类型为object的对象、数组和日期
- Referenced file contains errors (http://www.springframework.org/schema/context/spring-context-4.1.xs
- 排序
- mybatis redis 实现二级缓存
- 程序员的工作、学习与绩效
- Android ButterKnife 的安装使用和控件为Null处理
- 泛型
- 2、(二)在eclipse里如何查看JDK源码
- 深圳拉米拉手机云控营销系统有哪些功能
- 9 Three.js使用性能插件stats进行性能监听
- 读写分离——读写锁ReadWriteLock