题目
题目链接:算法技能树/蓝桥杯-基础/门牌制作
小蓝要为一条街的住户制作门牌号。
这条街一共有 2020 位住户,门牌号从 1 到 2020 编号。
小蓝制作门牌的方法是先制作 0 到 9 这几个数字字符,最后根据需要将字符粘贴到门牌上,例如门牌 1017 需要依次粘贴字符 1、0、1、7,即需要 1 个字符 0,2 个字符 1,1 个字符 7。
请问要制作所有的 1 到 2020 号门牌,总共需要多少个字符 2?
#include <bits/stdc++.h>
using namespace std;
int main()
{
int ans = 0, x;
for (int i = 1; i <= 2020; i++)
{
x = i;
while (x)
{
________________;
}
}
cout << ans;
return 0;
}
提示:
利用循环将当前数字的每一位求出,分别进行判断即可
分析
要统计门牌号上的每一个数字字符,那么就需要想办法把门牌号拆解开来
可以使用循环,每次对门牌号x用10除余,得到的是最后一位数用于判断是否是2,再用x除以10,得到最新的尾数,一直到x除以10得到结果为0了,就结束了。
以门牌号1234为例:
1234 % 10 = 4,ans = 0,
1234 / 10 = 123, 123 % 10 = 3,ans = 0
123 / 10 = 12, 12 % 10 = 2,ans = 1
12 / 10 = 1, 1 % 10 = 1,ans = 1
1 / 10 = 0,循环结束
代码
#include <bits/stdc++.h>
using namespace std;
int main() {
int ans = 0, x;
for (int i = 1; i <= 2020; i++) {
x = i;
while (x) {
if(x % 10 == 2) {
ans++;
}
x /= 10;
}
}
cout << ans;
return 0;
}