9. 回文数

2019-05-08  本文已影响0人  好吃红薯

判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。

示例 1:
输入: 121
输出: true

示例 2:
输入: -121
输出: false
解释: 从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。

示例 3:
输入: 10
输出: false
解释: 从右向左读, 为 01 。因此它不是一个回文数。

思路一(224 ms):装入list,list反转,判断是否相同。

class Solution(object):
    def isPalindrome(self, x):
        """
        :type x: int
        :rtype: bool
        """
        if x<0:
            return False
        
        res = []
        while(x):
            res.append(x%10)
            x = x//10
        
        v = copy.deepcopy(res)
        res.reverse()
        
        return res == v

思路二(152 ms):字符串反转,利用切片,反向步进

class Solution(object):
    def isPalindrome(self, x):
        """
        :type x: int
        :rtype: bool
        """
        return str(x)==str(x)[::-1]
上一篇 下一篇

猜你喜欢

热点阅读