首页 > 其他 > 详细

回文数

时间:2020-03-02 13:48:31      阅读:53      评论:0      收藏:0      [点我收藏+]

判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。

示例 1:

输入: 121
输出: true

示例 2:

输入: -121
输出: false
解释: 从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。

示例 3:

输入: 10
输出: false
解释: 从右向左读, 为 01 。因此它不是一个回文数。

代码如下:

bool isPalindrome(int x){

    if(x<0)
        return 0;
    
    int tmp = x;
    long num_reverse = 0;
    while(0 != tmp)//判断传入的参数是否已经转换完毕
    {
        num_reverse = num_reverse * 10 + tmp % 10; // 从最低位开始取传入参数的每一位数字,并将取得的数字放入到倒置之后的变量中
        tmp = tmp / 10;//获取剩余的部分数字
    }

    return !(num_reverse ^ x); // 判断是否相等,这两个数字


}
题解思路如下:

如果是负数,则直接不许要判断,直接返回0, 说明不是回文数;

如果是正数,则将整个数每一位倒置,然后与传入的参数进行异或操作,如果结果为0, 则说明,是回文数,否则就不是回文数,其中要注意到倒置之后可能引起的int型越界的问题

,所以在此处用了long对倒置之后的数字进行接收。



来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/palindrome-number
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

回文数

原文:https://www.cnblogs.com/pigdragon/p/12395009.html

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