一、题目
小蓝要为一条街的住户制作门牌号。
这条街一共有2020位住户,门牌号从1到2020编号。
小蓝制作门牌的方法是先制作0到9这几个数字字符,最后根据需要将字符粘贴到门牌上,例如门牌1017需要依次粘贴字符1、0、1、7,即需要1个字符0,2个字符1,1个字符7。
请问要制作所有的1到2020号门牌,总共需要多少个字符2?
二、代码
import java.util.HashMap;
import java.util.Set;
public class Main {
public static void main(String[] args) {
HashMap<Integer,Integer> map = new HashMap<>();
map.put(0,0);
map.put(1,0);
map.put(2,0);
map.put(3,0);
map.put(4,0);
map.put(5,0);
map.put(6,0);
map.put(7,0);
map.put(8,0);
map.put(9,0);
for (int i = 1; i <= 2020; i++) {
int num = i;
while(num!=0){
int tmp =num % 10;
map.put(tmp,map.get(tmp)+1);
num = num /10;
}
}
//输出map
// Set<Integer> keySet = map.keySet();
// for (Integer key:keySet){
// System.out.println(key);
// }
System.out.println(map.get(2));
}
}