9.回文数

Determine whether an integer is a palindrome. An integer is a palindrome when it reads the same backward as forward.

Example 1:

Input: 121
Output: true
Example 2:

Input: -121
Output: false
Explanation: From left to right, it reads -121. From right to left, it becomes 121-. Therefore it is not a palindrome.
Example 3:

Input: 10
Output: false
Explanation: Reads 01 from right to left. Therefore it is not a palindrome.
Follow up:

Coud you solve it without converting the integer to a string?

思路

回文数在操作上所需要的技巧有点类似于整数反转,比起整数反转,所需要加的控制条件为控制负数返回false,反转后不相等返回false。但是反转后的数字没有了限制位数的控制条件。但我们不需要像整数反转那样将整个数字反转过来于原数进行比较,我们只需反转它的一半,与剩下的进行比较,这样我们也不用解决溢出问题了。

1.

设置负数false

2.

数字未到一半的控制条件应为已经被反转的数小于还未进行反转的数。
那么如果这个数字的位数是奇数的话,已反转与未反转的数肯定是不相同的,只需在判断的地方加一个或者的控制条件,即i= =revh||i= =revh/10,这样只是增加了一条指令的代价。

3.

还有一种情况就是,我们要注意0这个数字,结尾为零,我们花一条指令的代价将这种情况剔除,即第一次对10除余为零但数字本身不为零。

bool isPalindrome(int x) {
    int revh=0;
    int i;
    if(x<0)
        return false;
    else if(0==x%10&&0!=x)
        return false;
    else{
        i=x;
        while(i>revh){
            revh=i%10+revh*10;
            i/=10;
           }
        if(i==revh||i==revh/10)
            return true;
        else
            return false;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值