制作1~2020门牌号共需要几个2字符?

题目描述
小蓝要为一条街的住户制作门牌号。这条街一共有2020位住户,门牌号从1到2020编号。小蓝制作门牌的方法是先制作0到9这几个数字字符,最后根据需要将字符粘贴到门牌上,例如门牌1017需要依次粘贴字符1、0、1、7,即需要1个字符0,2个字符1,1个字符7。请问要制作所有的1到2020号门牌,总共需要多少个字符2?
 

  根据题目意思可以得出,要求算出1到2020共有多少个2,首先必然要用到循环结构,那么其次,有人会问2在各位好算,十位百位千位呢?这就是这个题目的考点所在,看你对于/跟%熟不熟悉,我们会发现,一个数/10,那么就去掉了最低位,因此,可以用循环结构每/10,就%10看是否等于二

 代码如下

#include
using namespace std;
int judge(int number){
	int acount=0;
	while(number){
		if(number%10==2)
		acount++;
		number/=10;
	}
	return acount;
}
int main(){
	int count=0;
	for(int i=1;i<=2020;i++){
		count+=judge(i);
	}
	cout<

你可能感兴趣的:(代码,蓝桥杯,c++)