leetcode 回文串问题,判断回文串

解法一:将其转化为字符串,再对字符串进行前后比较。

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最大值 最小值的一个方法。

发布了39 篇原创文章 · 获赞 2 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/m0_37962192/article/details/104352886