目录
题目:门牌制作:
小蓝要为一条街的住户制作门牌号。
这条街一共有 2020 位住户,门牌号从 1 到 2020 编号。
小蓝制作门牌的方法是先制作 0 到 9 这几个数字字符,最后根据需要将字符粘贴到门牌上,
例如门牌 1017 需要依次粘贴字符 1、0、1、7,即需要 1 个字符 0,2 个字符 1,1 个字符 7。
请问要制作所有的 1 到 2020 号门牌,总共需要多少个字符 2?
解题思路:
1.他制作了十个个位数来拼凑门牌号
2.那么验证是否存在2这个数字就用求余10看等不等与2
3.当遇见20这样的求余怎么解决
代码如下 :
public static void main(String[] args) {
int a = 0;
for (int i = 1; i <= 2020; i++) {
int b = i;//这里不可以直接使用i,否则会发生死循环
while (b>1) {
if (b % 10 == 2)//在这里求余判断 {
a++;
}
b/=10; //再次判断
}
}
System.out.println(a);
}
最后打印:
总结:
遍历所有数字,每个数字均判断有多少个2;
判断2的方法:
对各个位数不停的判断,先判断个位,而后除以10,再次判断,定义一个计数器,每出现一个2加一;