题目描述
小蓝要为一条街的住户制作门牌号。这条街一共有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<iostream>
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<<count<<endl;
return 0;
}