题目
判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
示例 1:
输入: 121
输出: true
示例 2:
输入: -121
输出: false
解释: 从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。
示例 3:
输入: 10
输出: false
解释: 从右向左读, 为 01 。因此它不是一个回文数。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/palindrome-number
思路:
- 首先排除负数,若输入的为负数,直接返回false;
- 反转整数
- 反转前后对比得到答案(相等则为回文数)
代码实现
//判断回文数2019/11/15
public boolean isPalindrome(int x) {
if(x<0){
return false;
}
int s1=reverse(x);
if(s1==x){
return true;
}else{
return false;
}
}
//整数反转
public int reverse(int A) {
boolean neg = A < 0;
A = Math.abs(A);
long ret = 0;
while(A != 0){
ret = ret*10 + A%10;
A = A/10;
}
if(ret > Integer.MAX_VALUE) return 0;
return neg ? -(int)ret : (int)ret;
}
//判断回文数/2019/11/15