首页 > 技术文章 > 回文数

pigdragon 2020-03-02 12:43 原文

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

示例 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
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

推荐阅读