1. 题目:回数是指从左向右读和从右向左读都是一样的数,例如12321,909。请利用filter()筛选出回数:
1.1 解答一:这是我个人的第一种方式
# 回数是指从左向右读和从右向左读都是一样的数,例如12321,909。请利用filter()筛选出回数:
def reverseStr(n):
result = ""
for i in str(n):
result = i + result
return int(result)
def is_palindrome(n):
if n == reverseStr(n):
return True
# 测试:
output = filter(is_palindrome, range(1, 1000))
print('1~1000:', list(output))
if list(filter(is_palindrome, range(1, 200))) == [1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 22, 33, 44, 55, 66, 77, 88, 99, 101, 111, 121, 131, 141, 151, 161, 171, 181, 191]:
print('测试成功!')
else:
print('测试失败!')
1.2 个人解答第二种
上面的第一种有些繁琐,加以变换,就成了下面这种。
def is_palindrome(n):
nn = str(n) #转成字符串
return nn == nn[::-1] #反转字符串并对比原字符串返回true/false
print list(filter(is_palindrome,range(1,1000)))
1.3 一位前辈的解答
这种方式更加的简单,思路是一样的,都是将数字转为字符串然后逆转比较
print list(filter(lambda n : str(n)==str(n)[::-1],range(1,1000))) #str(n)同上