解法一:将其转化为字符串,再对字符串进行前后比较。
class Solution:
def isPalindrome(self, x: int) -> bool:
if x < 0:
return False #发现负数不可能是回文串,所以在这里直接判断
x = str(abs(x)) #这里可以去掉绝对值,因为不可能是负数
if len(x) == 1:
return True
for i in range((len(x)+1)//2): #判断前半部分就够了
if x[i] != x[len(x)-1-i]:
return False
return True
解法二:官方题解,不转化为字符串。
我觉得题解里有两点可以借鉴的地方,一个部分是对于数据溢出的注意,另一方面是判断是否处理了这个整数的一半,对于其他相似的整数取半具有参考意义。
另外附上python获得32int最大值 最小值的一个方法。