leetcode 9. 判断整数是否是回数 Palindrome Number

Palindrome Number

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

注:回数是指正读和倒读都一样的数,如121,234432

解题分析:

需要注意点
(1)负数不是回数
(2)个位数都是回数
思路:
(1)使用前一题的整数的倒序,将一个数倒序,然后和原值比较:存在的问题是可能有溢出,需要计算每一位,影响高效,有改进空间
(2)逐个比较最高位和最低位,不等跳出,相等就比较次高位和次低位,递归结束:高效,但难度是如何取得最高位掐头去尾

程序实现

(1)整数的倒序

bool isPalindrome(int x) {
    long long y = 0;
    int t = x;
    for (; t > 0; t /= 10)
        y = y*10 + t %10;
    if(x == y)
        return true;
    return false; //如果溢出,肯定不等
}

(2)逐个比较最高位和最低位

bool isPalindrome(int x) {
        if (x < 0)
            return false;
        int d = 1;
        while (x / d >= 10) //计算取最高位所需的除数
            d *= 10;
        while (x)
        {
            int high_bit = x / d;
            int low_bit = x % 10;
            if (high_bit != low_bit)
                break;
            x = x % d / 10; //*掐头去尾*
            d = d / 100; //每次踢出2位
        }
        if (x)
            return false;
        return true;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值