题目描述
本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。
小蓝要为一条街的住户制作门牌号。这条街一共有 2020 位住户,门牌号从
1 到 2020 编号。小蓝制作门牌的方法是先制作 0 到 9 这几个数字字符,最后根据需要将字符粘贴到门牌上,例如门牌 1017 需要依次粘贴字符
1、0、1、7,即需要 1 个字符 0,2 个字符 1,1 个字符 7。
请问要制作所有的 1 到 2020 号门牌,总共需要多少个字符 2?
实现代码
#include <iostream>
#include<bits/stdc++.h>
using namespace std;
int main()
{
int num=2020;
int count=0;
int yu=0;
int shang=0;
for(int i=1;i<=num;i++)
{
shang=i;
yu=shang%10;
//cout<<"现在是:"<<i<<endl;
while(shang>0)
{
yu=shang%10;
//cout<<yu<<endl;
if(yu==2)
{
count++;
}
shang=shang/10;
}
}
cout<<count<<endl;
return 0;
}
解题思路
其实这个有一种简单做法,首先用程序输出这些数,然后放到文字处理器里搜索 2 就行。
本代码的思路是从 1 到 2020 都循环一次,判断每个数的每一位是不是 2 ,是的话 count +1,最后输出 count 。
注意点
注意下面这一段,while 的条件应该是 shang>0,不是 yu>0 ,否则出现一个 0 的时候就会停。
while(shang>0)
{
yu=shang%10;
if(yu==2)
{
count++;
}
shang=shang/10;
}
知识点
对于连续(大量)数字的每一位进行操作:
while(shang>0)
{
yu=shang%10;
if(yu==2)
{
count++;
}
shang=shang/10;
}