小明非常不喜欢数字2,包括那些数位上包含数字2的数。如果一个数的数位不包含数字2,小明将它称为洁净数。
请问在整数1至n中,洁净数有多少个?
一.正确代码
import os
import sys
n=int(input())
count=0
for i in range(1,1+n):
j=str(i)
for k in j:
if k=='2':
break
else:
count+=1
print(count)
运行结果举例:输入30,输出18。
二.知识点
1.for循环(遍历循环)
拓展模式:for <变量> in <数据集合>:
<语句块1>
else:
<语句块2>
else语句只在循环正常执行后才执行并结束,当循环中遇到break保留字则不会执行else语句块。
2.break:
用来跳出最内层for或者while循环
三.解题思路
键盘输入整数,放入循环语句中对从1到n的每个数i进行判断,“一个数的数位不包括2”-->将每个数i类型转化为字符串j,再一次对字符j进行循环,将字符j的每一个单字符k提取出来,从而判断字符符k是否与字符2相等。