029-数字统计
总时间限制: 1000ms 内存限制: 65536kB
描述
请统计某个给定范围[L, R]的所有整数中,数字2出现的次数。
比如给定范围[2, 22],数字2在数2中出现了1次,在数12中出现1次,在数20中出现1次,在数21中出现1次,在数22中出现2次,所以数字2在该范围内一共出现了6次。
输入
输入共 1 行,为两个正整数 L 和 R,之间用一个空格隔开。
输出
输出共 1 行,表示数字 2 出现的次数。
样例输入
样例 #1:
2 22
样例 #2:
2 100
样例输出
样例 #1:
6
样例 #2:
20
来源
NOIP2010复赛 普及组 第一题
编程思路
如果 s 是个字符串,可以用 for x in s:的方式遍历这个字符串的每个字符
示例代码
s = input().split()
L = int(s[0])
R = int(s[1])
sum = 0
list = []
for i in range(L, R+1):
list.append(i)
s = str(list[0])
for i in range(1, len(list), 1):
s = s + str(list[i]) #将列表转换为字符串
for i in range(len(s)):
if (s[i] == "2"):
sum += 1
else :
continue
print(sum)
Accepted!