• 【ACM】hdu_1106_排序_201308071928


    排序
    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
    Total Submission(s): 27855    Accepted Submission(s): 7679


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

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


     

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

    输入数据保证:分割得到的非负整数不会大于100000000;输入数据不可能全由‘5’组成。

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

    Sample Input
    0051231232050775
     

    Sample Output
    0 77 12312320

    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #define MAX 550
    int a[MAX];
    char str[2*MAX];
    int cmp(const void *a,const void *b)
    {
        return *(int *)a-*(int *)b;
    }
    int main()
    {
        while(gets(str))
        {
            int i,j,k,t;
            memset(a,0,sizeof(a));
            t=0;
            for(i=0;(i<strlen(str))&&(str[i]=='5');i++);//清除开头的 5
            for(j=0;i<strlen(str);i++)
            {
                if(str[i]=='5')   
                {
                    if(str[i+1]==str[i])   //判断是不是连续的 5,
                    continue;
                    else
                    {a[j++]=t;t=0;}       //出现 5 ,则记录数据
                }
                else
                {
                    t=t*10+str[i]-'0';
                }
            }
            if(str[i-1]!='5')
            a[j++]=t;
            qsort(a,j,sizeof(a[0]),cmp);  //qsort排序
            for(i=0;i<j;i++)
            {
                if(i<j-1)
                printf("%d ",a[i]);
                else
                printf("%d ",a[i]);
            }
        }
        return 0;
    }

    //第一次错是因为没有考虑到连续的5的情况,以及末尾不是5的情况;第二次错是因为没有考虑到5在开头的情况;
    //总之,考虑问题太简单,不全面

  • 相关阅读:
    Windows Server 2008安装Memcached笔记
    解决powerDesinger12逆向工程报错:Unable to list the tables
    冒泡排序算法
    ASP.NET面试题(推荐_有答案)
    ASP.NET服务器控件分类简介
    将excel文件中的数据导入导出至SQL数据库中(Microsoft.Jet.OLEDB.4.0和Microsoft.ACE.OLEDB.12.0|office2003和office2007)
    关于sql access excel以及在web.config中数据库连接字符串的写法
    ODBC / OLEDB___DAO / RDO / ADO
    什么是CSV格式文档
    AppSettings和ConnectionStrings的区别
  • 原文地址:https://www.cnblogs.com/xl1027515989/p/3244131.html
Copyright © 2020-2023  润新知