美文网首页
【PAT-乙级-C++】1023. 组个最小数 (20)

【PAT-乙级-C++】1023. 组个最小数 (20)

作者: linghugoogle | 来源:发表于2018-01-21 23:43 被阅读28次

    1023. 组个最小数 (20)

    时间限制
    100 ms
    内存限制
    65536 kB
    代码长度限制
    8000 B
    判题程序
    Standard
    作者
    CAO, Peng

    1、题目

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

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

    输入格式:

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

    输出格式:

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

    输入样例:
    2 2 0 0 0 3 0 0 1 0
    输出样例:
    10015558
    

    2、代码

    #include<iostream>
    using namespace std;
    int main() {
        int a[10];
        int i,j;
        //读入数据
        for (i = 0;i < 10;++i) {
            cin >> a[i];
        }
        //TODO,对a[0]不等于0,其他为0进行判断
    
        //对a[0]进行判断
        if (a[0] == 0) {
            //对a[i]是否为0进行判断
            for (i = 1;i < 10;++i) {
                if(a[i]==0){}
                else {
                    for (j = 0;j < a[i];++j) 
                        cout << i;
                }
            }
        }
        //a[0]!=0
        else {
            //输出第一个非零数字和0
            i = 1;
            while (a[i] == 0) 
                ++i;
            cout << i;
            for (j = 0;j < a[0];++j) 
                cout << 0;
            for (j = 0;j < a[i] - 1;++j) 
                cout << i;
            //输出其他数字
            for (i+=1 ;i < 10;++i) {
                if (a[i] == 0) {}
                else {
                    for (j = 0;j < a[i];++j) {
                        cout << i;
                    }
                }
            }
        }
        system("pause");
        return 0;
    }
    

    相关文章

      网友评论

          本文标题:【PAT-乙级-C++】1023. 组个最小数 (20)

          本文链接:https://www.haomeiwen.com/subject/iukcaxtx.html