#方案一:
def is_palindrome(n):
nn = str(n) #转成字符串
return nn == nn[::-1] #反转字符串并对比原字符串返回true/false
print list(filter(is_palindrome,range(1,1000)))
#方案二:
print list(filter(lambda n : str(n)==str(n)[::-1],range(1,1000))) #str(n),同上
#方案三:
def is_palindrome(n):
s = str(n)
h = list(range((len(s))//2))
for i in h:
if s[i] != s[-(i+1)]:
return False
return True
#测试:
N = list(filter(is_palindrome,[1231, 121, 22, 1134341, 13431]))
tips
" / " 表示浮点数除法,返回浮点结果;
" // " 表示整数除法,返回不大于结果的一个最大的整数
filter()也接收一个函数和一个序列。和map()不同的是,filter()把传入的函数依次作用于每个元素,然后根据返回值是True还是False决定保留还是丢弃该元素。
filter()函数返回的是一个Iterator,也就是一个惰性序列,所以要强迫filter()完成计算结果,需要用list()函数获得所有结果并返回list。