zoukankan      html  css  js  c++  java
  • 编程题目: PAT 1023. 组个最小数 (20)

    1023. 组个最小数 (20)

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

    给定数字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
            本题也比较简单,要注意的就是在输入的0的个数不为0时,要首先确定第一位,然后顺序输出其他的就可以。参考代码如下:

    /*
    http://pat.zju.edu.cn/contests/pat-b-practise/1023
    */
    
    #include<iostream>
    #include<string>
    #include<vector>
    using namespace std;
    int main()
    {
    	vector<int> v(10);
    	for(int i=0;i<10;i++)
    	{
    		cin>>v[i];
    	}
    	if(v[0]!=0)
    	{
    		int j;
    		for( j=1;j<10&&v[j]==0;j++);
    		cout<<j;
    		v[j]--;
    	}
    	for(int i=0;i<10;i++)
    	{
    		while(v[i]!=0)
    		{
    			cout<<i;
    			v[i]--;
    		}
    	}
    	cout<<endl;
    	system("pause");
    	return 0;
    }
    




            


  • 相关阅读:
    mysql中delimiter
    error: unpacking of archive failed on file /usr/sbin/zabbix_agent;592e5bc3: cpio: open
    CefSharp中文帮助文档
    ASP.NET Aries 开发框架
    简洁的富文本编辑器
    asp.net core 获取appsettings.json里的配置
    在asp.net core中使用NLog
    临时禁用Resharper
    visual studio 无添加视图 选项
    visual studio(vs)初始化
  • 原文地址:https://www.cnblogs.com/f8master/p/3826049.html
Copyright © 2011-2022 走看看