python3中利用filter函数输出小于某个数的所有回文数

根据回文数的定义。先生成一个从0开始的整数无限序列

def _int_iter():
n = 0
while True:
yield n
n += 1

判断n是否为回文数,是就返回Ture,否就返回False

def _is_palindrome(n):
L1 = list(str(n))
L2 = L1[:] # 利用列表的切片将L1复制出一个副本,并将副本赋值给L2(以免对L2进行操作时,改变L1)
L2.reverse() #反转L2(reverse函数只对原Iterable进行反转,不会返回值)
return L1 == L2

利用filter进行筛选,只保留符合回文数要求的n值,并返回一个惰性的序列

def palindromes():
it = _int_iter()
while True:
n = next(it)
yield n
it = filter(_is_palindrome, it)

输出小于100000的所有回文数

for num in palindromes():
if num < 100000:
print(num)
else:
break

猜你喜欢

转载自blog.csdn.net/weixin_44119383/article/details/86663671