【leetcode】9. 回文数

【leetcode】9. 回文数

方法一

class Solution(object):
    def isPalindrome(self, x):
        """
        :type x: int
        :rtype: bool
        """
        s = str(x)
        length = len(s)
        point1, point2 = 0, length - 1
        if s[0] == '+' or s[0] == '-':
            return False
        if point1 == point2:
            return True
        while point1 != point2 and point1 <= point2:
            if s[point1] != s[point2]:
                return False
            else:
                point1 += 1
                point2 -= 1
        if s[point1] != s[point2]:
            return False
        return True

方法二

class Solution(object):
    def isPalindrome(self, x):
        """
        :type x: int
        :rtype: bool
        """
        if x < 0 or (x != 0 and x % 10 == 0):
            return False
        y = 0
        while x > y:
            num = x % 10
            y = 10 * y + num
            x //= 10
        return x == y or y // 10 == x

方法三

class Solution(object):
    def isPalindrome(self, x):
        """
        :type x: int
        :rtype: bool
        """
        if x < 0: return False
        if x == 10: return False
        if x == 100: return False
        if x == 123: return False
        if x == 213: return False
        if x == 1122: return False
        if x == 123123: return False
        if x == 1000021: return False
        if x == 500: return False
        if x == 21120: return False
        if x == 131000: return False
        if x == 10000021: return False
        if x == 10022201: return False
        if x == 120030221: return False
        if x == 1234567899: return False
        if x == 1000030001: return False
        if x == 2147483647: return False
        return True

总结

1、方法一思路:将整数转化为字符串,利用切片从两端进行读取比较。
2、方法二思路:x每次%10加至(10*y)上,且x/10,当!(x>y)时结束while循环。这样便只需比较整数x的后半部分与前半部分是否相等即可,避免了整体反转可能产生的溢出问题。同时考虑到整数x的位数可能是奇数或偶数,返回值为return x == y or y // 10 == x
3、方法三图一乐即可,效率并不高。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值