PAT乙级1023

题目链接

https://pintia.cn/problem-sets/994805260223102976/problems/994805298269634560

题解

主要就是控制首位不能为0,其他的都很简单,就遍历然后往尾部加数字就好了。

// PAT BasicLevel 1023
// https://pintia.cn/problem-sets/994805260223102976/problems/994805298269634560

#include <iostream>
using namespace std;

int main()
{
    // 结果
    string res="";
    
    // 获取数字零的数量
    int zeroCount;
    cin >>zeroCount;

    // 标志是否为第一个数量超过0个的数字
    bool isFirst=true;

    // 非零数字个数
    int count;

    // 获取非零数字的数量并生成最终结果
    for(char c='1';c<='9';++c){
        // 获取非零数数量
        cin >> count;
        
        // 该数字的数量超过0个时
        if(count>0){
            
            // 如果是第一个数量超过0的非零数字
            if (isFirst){
                // 先把它加在最前边,因为首位不可以是0
                res+=c;
                count--;

                // 把零加在前边
                for(int i=0;i<zeroCount;++i){
                    res+='0';
                }

                // 更新标志
                isFirst=false;
            }
            // 加自己
            for (int i = 0; i < count; ++i){
                res += c;
            }
        }
    }

    // 输出形成的最小数
    cout << res;

    //system("pause");
    return 0;
}

作者:@臭咸鱼

转载请注明出处:https://www.cnblogs.com/chouxianyu/

欢迎讨论和交流!


posted @   臭咸鱼  阅读(146)  评论(0编辑  收藏  举报
编辑推荐:
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
· C# 深度学习:对抗生成网络(GAN)训练头像生成模型
阅读排行:
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 本地部署DeepSeek后,没有好看的交互界面怎么行!
· 趁着过年的时候手搓了一个低代码框架
· 推荐一个DeepSeek 大模型的免费 API 项目!兼容OpenAI接口!
· 用 C# 插值字符串处理器写一个 sscanf
点击右上角即可分享
微信分享提示