LeetCode 9. 回文数

作者: SmallRookie | 来源:发表于2018-12-08 23:54 被阅读4次

    题目描述

    题解

    简单法

    class Solution {
    public:
        bool isPalindrome(int x) {
            long rev = 0;
            int tmp = x;
            if(x == 0) return true;
            if(x < 0 || (x % 10 == 0 && x != 0)) return false; 
            while(x != 0) {
                int pop = x % 10;
                x /= 10;
                rev = rev * 10 + pop;
            }
            if (rev == tmp) return true;
            else return false;
        }
    };
    

    反转一半数字

    class Solution {
    public:
        bool isPalindrome(int x) {
            int rev = 0;
            // 特殊情况:
            // 如上所述,当 x < 0 时,x 不是回文数。
            // 同样地,如果数字的最后一位是 0,为了使该数字为回文,
            // 则其第一位数字也应该是 0
            // 只有 0 满足这一属性
            if(x < 0 || (x % 10 == 0 && x != 0)) return false;
            while(x > rev) {
                int pop = x % 10;
                rev = rev * 10 + pop;
                x /= 10;
            }
            // 当数字长度为奇数时,我们可以通过 revertedNumber/10 去除处于中位的数字。
            // 例如,当输入为 12321 时,在 while 循环的末尾我们可以得到 x = 12,revertedNumber = 123,
            // 由于处于中位的数字不影响回文(它总是与自己相等),所以我们可以简单地将其去除。
            return x == rev || x == rev / 10;
        }
    };
    

    相关文章

      网友评论

        本文标题:LeetCode 9. 回文数

        本文链接:https://www.haomeiwen.com/subject/xunchqtx.html