前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[Leetcode][python]Palindrome Number/回文数

[Leetcode][python]Palindrome Number/回文数

作者头像
蛮三刀酱
发布2019-03-26 17:08:23
4870
发布2019-03-26 17:08:23
举报

题目大意

判断一个整数(integer)是否是回文,不要使用额外的空间。

解题思路

大概就是告诉我们:

1,负数都不是回文数;

2,不能通过将数字转为字符串来判断回文,因为使用了额外的空间(即只能使用空间复杂度 O(1) 的方法);

3,注意整数溢出问题;

4,这个问题有一个比较通用的解法。

代码

生成一个反转整数,通过比较反转整数和原整数是否相等来判断回文。

如果要进一步改进,实际上将原数字反转一半就可以判断是否是回文了。另外,以0结尾的非零数都不是回文。

代码语言:javascript
复制
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:
            y = y*10 + x%10
            x = x/10
        return x == y or y/10 == x

我提交的

代码语言:javascript
复制
class Solution(object):
    def isPalindrome(self, x):
        """
        :type x: int
        :rtype: bool
        """
        if x < 0:
            return False
        temp = x 
        y = 0 
        while temp:
            y = y*10 + temp%10
            temp /= 10
        return x == y

总结

由于不允许占用额外空间,所以不能将其分为字符串来做。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017年07月07日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目大意
  • 解题思路
  • 代码
  • 我提交的
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档