• 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 }

  • 相关阅读:
    JS通过组装key值访问json对象中的值
    js属性对象的hasOwnProperty方法
    ES6 去掉已经 new Date().format 方法
    Ajax不能接受php return值的原因
    CentOS最常用命令及快捷键整理
    js中for循环中需要调用异步方法,怎么确保执行的顺序?
    MYSQL 更新字段,向字段追加字符串
    java-学习2
    java-学习1
    JS----贪吃蛇游戏
  • 原文地址:https://www.cnblogs.com/qiufeihai/p/2322154.html
Copyright © 2020-2023  润新知