7. 整数反转
难度简单1740
给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
示例 1:
输入: 123
输出: 321
示例 2.
输入: -123
输出: -321
示例 3:
输入: 120
输出: 21
class Solution {
public int reverse(int x) {
int rev=0;
while(x!=0){
int pop=x%10;
x/=10;
if(rev>Integer.MAX_VALUE/10||(rev==Integer.MAX_VALUE/10&&pop>7))return 0;
if(rev<Integer.MIN_VALUE/10||(rev==Integer.MIN_VALUE/10&&pop<-8))return 0;
rev=rev*10+pop;
}
return rev;
}
}
反转不会做,网上找了答案,看了好多种,基本都有错误,就选了官方答案
题解:
if (rev > Integer.MAX_VALUE/10 || (rev == Integer.MAX_VALUE / 10 && pop > 7)) return 0;
if (rev < Integer.MIN_VALUE/10 || (rev == Integer.MIN_VALUE / 10 && pop < -8)) return 0;
7和8是int所能表达的边缘数
所以这串代码是判断有没有超过界限