判断一个整数是否是回文数(整数不含前导零)
思路:将整数翻转后判断是否与原整数相等
简单的翻转方法用到切片(Slice),将整数强制转换为字符串,用切片[ : : -1] 翻转后比较
代码:
# -*- coding: UTF-8 -*-
def is_palindrome(n):
n=str(n)
m=int(n[::-1])
n=int(n)
return n==m
# 测试:
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('测试失败!')
结果: