zoukankan      html  css  js  c++  java
  • hdu 1106 排序(水题)

    题目描述:

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

    输入:

      输入包含多组测试用例,每组输入数据只有一行数字(数字之间没有空格),这行数字的长度不大于1000。输入数据保证:分割得到的非负整数不会大于100000000;输入数据不可能全由‘5’组成。

      例如:0051231232050775

    输出:

      对于每个测试用例,输出分割得到的整数排序的结果,相邻的两个整数之间用一个空格分开,每组输出占一行。

      例如:0 77 12312320

    解题思路:

      题目不难,注意细节。之前坑在了中间有一堆5的测试数据上。

      字符串转成整数的方法:sscanf函数(string.h头文件中)、atoi函数(stdlib.h头文件中)

      给出几个测试数据:

      (1)开头带一个5:5123

      (2)开头带许多5:55555123

      (3)结尾带一个5:1235

      (4)结尾带许多5:12355555

      (5)中间带许多5:12355555456

      (6)全零序列:000000000000000000000000000000000000000

      (7)没有5:123

    AC代码:

     1 #include <stdio.h>
     2 #include <string.h>
     3 #include <vector>
     4 #include <algorithm>
     5 #include <functional>
     6 
     7 char szSeq[1010];
     8 int iHead, iTail;
     9 std::vector<int> vecNums;
    10 
    11 void Init()
    12 {
    13     vecNums.clear();
    14     iHead = 0;
    15     iTail = strlen(szSeq);
    16 }
    17 
    18 int GetNumber()
    19 {
    20     char szNum[1010] = { 0 }; // 虽然数字大小不会超过100000000,但是如果很多的0呢,数组开小了,会越界。
    21     int iCount = 0, iNum = -1;
    22     int flag = false;          // false:未获取到数字;true:获取到数字
    23     while (iHead < iTail && '5' == szSeq[iHead]) ++iHead; // 处理数字前面的'5'
    24     while (iHead < iTail && '5' != szSeq[iHead])          // 获取数字
    25     {
    26         flag = true;
    27         szNum[iCount++] = szSeq[iHead++];
    28     }
    29     if (true == flag)
    30         sscanf(szNum, "%d", &iNum);  //把字符转换成数字
    31     return iNum;
    32 }
    33 
    34 void OutPutVec()
    35 {
    36     for (std::vector<int>::iterator iter = vecNums.begin(); iter != vecNums.end(); ++iter)
    37     {
    38         if (iter == vecNums.begin())
    39             printf("%d", *iter);
    40         else
    41             printf(" %d", *iter);
    42     }
    43     printf("
    ");
    44 }
    45 
    46 int main(void)
    47 {    
    48     int iNum;
    49     while (EOF != scanf("%s", szSeq))
    50     {
    51         Init();
    52 
    53         //从数字序列中获取所有的数字放入vecNums容器中
    54         while (-1 != (iNum = GetNumber()))
    55             vecNums.push_back(iNum);
    56 
    57         std::sort(vecNums.begin(), vecNums.end(), std::less<int>());
    58 
    59         OutPutVec();
    60     }
    61     return 0;
    62 }
  • 相关阅读:
    bzoj 1031: [JSOI2007]字符加密Cipher 後綴數組模板題
    hdu3949 XOR xor高斯消元
    The xor-longest Path
    Contest20140906 反思
    Contest20140906 ProblemC 菲波拉契数制 DP
    Contest20140906 ProblemA dp+线段树优化
    bzoj 1257: [CQOI2007]余数之和sum 数学 && 枚举
    tyvj P1716
    BZOJ 1012 [JSOI2008]最大数maxnumber【线段树】
    Bzoj1083 1083: [SCOI2005]繁忙的都市【MST】
  • 原文地址:https://www.cnblogs.com/yongqiang/p/6260544.html
Copyright © 2011-2022 走看看