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

leetcode 回文串问题,判断回文串_第1张图片

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

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

解法二:官方题解,不转化为字符串。

leetcode 回文串问题,判断回文串_第2张图片

leetcode 回文串问题,判断回文串_第3张图片

我觉得题解里有两点可以借鉴的地方,一个部分是对于数据溢出的注意,另一方面是判断是否处理了这个整数的一半,对于其他相似的整数取半具有参考意义。

解法三 参考leetcode另一个同学的题解https://leetcode-cn.com/problems/palindrome-number/solution/dong-hua-hui-wen-shu-de-san-chong-jie-fa-fa-jie-ch/,值得借鉴的地方是判断整数总共是多少位,一方面前后同时进行比较。

leetcode 回文串问题,判断回文串_第4张图片

leetcode 回文串问题,判断回文串_第5张图片

另外附上python获得32int最大值 最小值的一个方法。

leetcode 回文串问题,判断回文串_第6张图片

你可能感兴趣的:(leetcode)