给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
示例 1:
输入: 123
输出: 321
示例 2:
输入: -123
输出: -321
示例 3:
输入: 120
输出: 21
思路:
将数字对10取模得到高一位 再来进行判断
//int能表示的范围 2^31-1=2147483647,-2^31=-2147483648
public int reverse(int x) {
long res = 0;
while (x != 0){
res = res * 10 + x % 10;
x = x / 10;
}
//直接返回不合法的
if (res > Integer.MAX_VALUE || res < Integer.MIN_VALUE){
return 0;
}
return (int)res;
}