HDU 1106 排序

排序

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 17926    Accepted Submission(s): 4669


Problem Description
输入一行数字,如果我们把这行数字中的‘5’都看成空格,那么就得到一行用空格分割的若干非负整数(可能有些整数以‘0’开头,这些头部的‘0’应该被忽略掉,除非这个整数就是由若干个‘0’组成的,这时这个整数就是0)。

你的任务是:对这些分割得到的整数,依从小到大的顺序排序输出。

 
Input
输入包含多组测试用例,每组输入数据只有一行数字(数字之间没有空格),这行数字的长度不大于1000。  

输入数据保证:分割得到的非负整数不会大于100000000;输入数据不可能全由‘5’组成。
 
Output
对于每个测试用例,输出分割得到的整数排序的结果,相邻的两个整数之间用一个空格分开,每组输出占一行。
 
Sample Input
0051231232050775
 
Sample Output
0 77 12312320
 
 
 
 
 
开始做时,是想把每组数字用字符数组储存,然后利用sscanf转给整形数组,再用快排。
 
其实直接把字符数字转化成数字直接给整形数组就可以了。
 
 
总结:1~字符数字转成整形数字。(从高位开始,即c[0]时高位而不是个位。)
s = 0;
......
s *= 10;
s += *p - '0';
p ++;
 
 
 
2~while()和if()的结合使用不够精。
 
while(*p.....)//这个模板就是处理*p符合某条件的一段。如果还有什么额外条件的话,进循环马上if(),见下面代码。
{
  p++;
}
 
 
 
 
3~三目运算符
i == 0 ? printf("%d",a[i]) : printf(" %d",a[i]);       不够简洁。。。
 
 
简洁的:printf(i ? " %d" : "%d" ,a[i]);
 
 
4~新的换行方式:puts("");
 
 
View Code
 1 #include<stdio.h>
2 #include<string.h>
3 #include<stdlib.h>
4 #define maxn 1010
5 char c[maxn];
6 int a[maxn];
7 int cmp(const void* a,const void* b)
8 {
9 return *(int*)a - *(int*)b;
10 }
11 int main()
12 {
13 int n,s,i;
14 char *p;
15 while (gets(c) != NULL)
16 {
17 p = c;
18 n = 0;
19 while(*p)//处理有效字符。
20 {
21 s = 0;
22 if(*p == '5')//从非5开始。
23 {
24 p++;
25 continue;
26 }
27 while(*p != '5')//处理不是5的一段。
28 {
29 if(*p == '\0')//因为可能到了最后。
30 {
31 p--;/*如果不清零的话,要有这个较好。此时指回最后一个有效字符*/
32 break;
33 }
34 s *= 10;//字符数字转整形数字。
35 s += *p - '0';
36 p++;/*上面用了p--后,这里p++刚好指再'\0',就算没清零继续判断也是结束。*/
37 }
38 a[n++] = s;//注意这个在上面的while()的外面。
39 p++;
40 }
41 qsort(a,n,sizeof(a[0]),cmp);
42 for(i = 0;i < n; i++)
43 {
44 printf(i ? " %d" : "%d" ,a[i]);
45 }
46 puts("");
47 }
48 return 0;
49 }

原文地址:https://www.cnblogs.com/qiufeihai/p/2322154.html