利用filter()滤掉非回数

来源:互联网 发布:node fs模块 编辑:程序博客网 时间:2024/06/05 11:26

代码可以优化的地方太多了,学习真是永无止境。每个人都有自己的见解,但是也会有一个最优解。


回数是指从左向右读和从右向左读都是一样的数,例如12321,909。请利用filter()滤掉非回数:

def is_palindrome(n):    a = repr(n)    if (a[0] == a[-1]) and (n % int(a[-1]) == 0):        if len(a) >1:            return noutput = filter(is_palindrome,range(1,1000))print (list(output))

输出结果:

[11, 22, 33, 44, 55, 66, 77, 88, 99, 101, 111, 121, 131, 141, 151, 161, 171, 181, 191, 202, 212, 222, 232, 242, 252, 262, 272, 282, 292, 303, 333, 363, 393, 404, 424, 444, 464, 484, 505, 515, 525, 535, 545, 555, 565, 575, 585, 595, 606, 636, 666, 696, 707, 777, 808, 848, 888, 909, 999]


0 0
原创粉丝点击