首页 > 其他 > 详细

Palindrome Number

时间:2014-11-03 22:24:40      阅读:296      评论:0      收藏:0      [点我收藏+]

Determine whether an integer is a palindrome. Do this without extra space.

要求是不能使用额外的空间,言下之意就是不能先转化成字符串来进行处理,所以得想另外一种办法。

额外考虑负数属于回文数字?

思路:直接来截取最低位和最高位来进行比较。然后去掉最高位最低位,再进行比较,如此循环。

最高位数字=x/10(n为x的位数)

最低位数字=x%10

去掉最低位和最高位:x=x%10n/10;

特殊值考虑:x=10021

1和1符合,进而x=2,base=10000/100=100。接着left=2/100=0;right=2%10=2;所以推出不等。

所以特殊0值成立。

class Solution {
public:
    bool isPalindrome(int x) {
        if(x<0) 
            return false;
        if(x==0) 
            return true;
        int base=1;
        while(x/base>=10)
            base*=10;

        while(x)
        {
            int left=x/base;
            int right=x%10;
            if(right!=left)
                return false;
            x=x%base/10;
            base=base/100;
        }
        return true;
    }
};

 

Palindrome Number

原文:http://www.cnblogs.com/fightformylife/p/4072199.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!