• 1023 组个最小数(满分)


    题目:

    给定数字 0-9 各若干个。你可以以任意顺序排列这些数字,但必须全部使用。目标是使得最后得到的数尽可能小(注意 0 不能做首位)。例如:给定两个 0,两个 1,三个 5,一个 8,我们得到的最小的数就是 10015558。

    现给定数字,请编写程序输出能够组成的最小的数。

    输入格式:

    输入在一行中给出 10 个非负整数,顺序表示我们拥有数字 0、数字 1、……数字 9 的个数。整数间用一个空格分隔。10 个数字的总个数不超过 50,且至少拥有 1 个非 0 的数字。

    输出格式:

    在一行中输出能够组成的最小的数。

    输入样例:

    2 2 0 0 0 3 0 0 1 0
    

    输出样例:

    10015558

     代码:

    #include
    #include

    int main()
    {
        int d0,d1,d2,d3,d4,d5,d6,d7,d8,d9;
        scanf("%d %d %d %d %d %d %d %d %d %d",&d0,&d1,&d2,&d3,&d4,&d5,&d6,&d7,&d8,&d9);
        int len=d0+d1+d2+d3+d4+d5+d6+d7+d8+d9;
        int out[len];
        int flag=0;//0表示没有0,1表示有0
        if(d0!=0)
        {
            flag=1;
        }
        for(int i=0;i     {
            if(d0!=0)
            {
                out[i]=0;
                d0--;
                continue;
            }
            if(d1!=0)
            {
                out[i]=1;
                d1--;
                continue;
            }
            if(d2!=0)
            {
                out[i]=2;
                d2--;
                continue;
            }
            if(d3!=0)
            {
                out[i]=3;
                d3--;
                continue;
            }
            if(d4!=0)
            {
                out[i]=4;
                d4--;
                continue;
            }
            if(d5!=0)
            {
                out[i]=5;
                d5--;
                continue;
            }
            if(d6!=0)
            {
                out[i]=6;
                d6--;
                continue;
            }
            if(d7!=0)
            {
                out[i]=7;
                d7--;
                continue;
            }
            if(d8!=0)
            {
                out[i]=8;
                d8--;
                continue;
            }
            if(d9!=0)
            {
                out[i]=9;
                d9--;
                continue;
            }
        }
        if(flag)
        {
            int i=0;
            for(;i         {
                if(out[i]!=0)
                {
                    break;
                }
            }
            int temp=out[i];
            out[i]=out[0];
            out[0]=temp;
        }
        for(int i=0;i     {
            printf("%d",out[i]);
        }
        return 0;
    }
     

  • 相关阅读:
    软件测试面试必备,一文带你彻底掌握接口测试
    [搞点好玩的] JETSONNANO 受苦记 -- 001 (布置环境,未完待续)
    【微信小程序】事件绑定和事件对象
    【vue实战项目】通用管理系统:作业列表
    Java安全—CommonsCollections1
    Jupyter Notebook本地部署并实现公网远程访问内网Jupyter服务器【内网穿透】
    Web前端开发之HTML_2
    计算机导论第十一周课后作业
    链表面试题-刷题
    Diverse Branch Block论文中对于串联卷积的融合中的一些理解点
  • 原文地址:https://blog.csdn.net/kawlyh/article/details/126453493