题目
判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
示例 1:
输入: 121 输出: true
示例 2:
输入: -121 输出: false 解释: 从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。
示例 3:
输入: 10 输出: false 解释: 从右向左读, 为 01 。因此它不是一个回文数。
进阶:
你能不将整数转为字符串来解决这个问题吗?
代码
小结
对于整数x, 想要取第i位(这里个位是1,十位是2,百位是3,以此类推)的数字,可以通过
>> x // (10 ** (i - 1)) % 10
例如:取1221的第4位(千位),可以通过1221 // (10 ** (4 - 1)) % 10 得到。
class Solution(object):
def isPalindrome(self, x):
"""
:type x: int
:rtype: bool
"""
if x < 0:
return False
b_len = len(str(x))
l = b_len
r = 1
while l > r:
if x // (10 ** (l - 1)) % 10 == x // (10 ** (r - 1)) % 10:
l -= 1
r += 1
else:
return False
return True
博客围绕判断整数是否为回文数展开,回文数指正序和倒序读都相同的整数。给出示例并提出进阶要求,即不将整数转为字符串解决问题。还给出取整数第i位数字的代码,如取1221千位数字的计算方法。

519

被折叠的 条评论
为什么被折叠?



