一.题目
题目描述
小明对数位中含有 2、0、1、9 的数字很感兴趣(不包括前导 0),在 1 到 40 中这样的数包括 1、2、9、10 至 32、39 和 40,共 28 个,他们的和是 574。
请问,在 1 到 n 中,所有这样的数的和是多少?
输入格式
输入一行包含一个整数 n。
输出格式
输出一行,包含一个整数,表示满足条件的数的和。
二.示例
输入
40
输出
574
三.思路
正确思路:将数字转化为字符的形式然后用 in 判断数据中是否含有题目要求的字符(要注意for循环的机制【依次取值】)
错误思路:以数的形式进行相关数据运算(无法准确判定数据处理后是否含有2019其中的一个)
四.代码
正确思路:
sums=0
n=int(input())
for i in range(1,n+1):
j=str(i)
if "2"in j or "0"in j or "1" in j or "9"in j:
sums+=i
print(sums)
错误思路:
n=int(input())
sums=0
for i in range(1,n+1):
if i%10==2 or i%10==0 or i%10==1 or i%10==9:
sums+=i
else:
f_num = i
while f_num:
f_num /= 10
n =f_num % 10
if n == 2 or n==0 or n ==1 or n == 9:
sums += i
print(sums)