C/C++教程

2021蓝桥杯C++B组第二题 卡片

本文主要是介绍2021蓝桥杯C++B组第二题 卡片,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
#include<iostream>
using namespace std;
int i; 
int main(){
    int cnt[10];//定义一个数组,存储1-9九个数字的使用情况 
    for(int i=0;i<10;i++)
        cnt[i]=2021;//对数组进行遍历,并赋初值2021 
    for(int i=1;;i++){ 
        int t=i;
        while(t){
            int a=t%10;//将数字的最后一位赋给a,此时a是最后一位数字,且cnt[a]代表a这个数字还剩下多少张。 
            if(cnt[a]>0)cnt[a]--;
            else break;//推出条件为数组元素大小小于0 
            t/=10;//不停除以10直到t为零循环终止。 
        }
        if(t){//这里if判断条件为什么是t呢,因为,再上面的while循环里,t最终会变为零 
            cout<<i;//因为上面的循环无退出的条件,所以这里的if纯在的意义就是让它退出循环 
            break;//退出的是当前的循环,for循环 
        }
    }
    cout<<i;
	return 0;
}
//3181

题解在注释里

这篇关于2021蓝桥杯C++B组第二题 卡片的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!