题目
给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。
回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。例如,121 是回文,而 123 不是。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/palindrome-number
题目给出了回文数的定义,负数不是回文数(-121不可能是121-的),由题意可知个位数都是回文数(0,1,2,3,4,5,6,7,8,9)
程序代码如下
class Solution{
public bolean isPalindorme(int x){
if(x<0||(x % 10 == 0 && x != 0))
{
return false;
}
int rNumber = 0;
while(x > rNumber){
rNumber = rNubmer * 10 + x % 10;
x /= 10;
}
return x == rNumber || x== rNumber / 10;
}
}
if(x<0||(x % 10 == 0 && x != 0))
{
return false;
}
一个数小于0必然不是回文数;除以10无余数个位数必然为0(这里的数都是非个位数),为了使该数字为回文,则其第一位数字也应该是 0,符合此条件的数只有0。
int rNumber = 0;
while(x > rNumber){
rNumber = rNubmer * 10 + x % 10;
x /= 10;
}
return x == rNumber || x== rNumber / 10;
}
用数学思维来判断是不是回文数