CSDN算法题Java解---门牌制作

目录

题目:门牌制作:

 解题思路:

代码如下 :

最后打印:

 总结:


题目:门牌制作:

小蓝要为一条街的住户制作门牌号。

这条街一共有 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加一;

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值