Tony540102689 2016-03-05 04:46 采纳率: 50%
浏览 3750
已结题

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

def is_palindrome(n):
s = str(n)
for i in range(len(s)):
if s[i] == s[len(s)-1-i]:
return True
else:
return False

output = filter(is_palindrome, range(1, 1000))
print(list(output))

谁来解释一下原理啊,特别是

for i in range(len(s)):
if s[i] == s[len(s)-1-i]

  • 写回答

3条回答 默认 最新

  • xSeeker~ 2016-03-05 05:41
    关注

    过滤前的数最多是3位,所以实际上只判断第一位和最后一位数字是否相同,就可以判断是否是回文数,而循环只执行了1次就return了
    当数字是1位数时,判端s[0] == s[1-1-0]
    当数字是2位数时,判端s[0] == s[2-1-0]
    当数字是3位数时,判端s[0] == s[3-1-0]

    这个函数的写法太实用,如果数字是4位数甚至更多位,就会出错,下面的函数是我写的,仅供参考:

    def is_palindrome(n):
    s = str(n)
    for i in range(len(s)/2):
    if s[i] != s[len(s)-1-i]:
    return False
    return True

    评论

报告相同问题?

悬赏问题

  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码