题目
7. 整数反转
给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
示例 1:
输入: 123
输出: 321
示例 2:
输入: -123
输出: -321
示例 3:
输入: 120
输出: 21
注意:
假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为
[−2^(31), 2^(31) − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。
即: [-2147483648, 2147483647]
解析:
代码:
import java.util.Scanner;
public class code7 {
public static 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;
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while (sc.hasNextInt()) {
int x1 = sc.nextInt();
int x2 = reverse(x1);
System.out.println(x2);
}
}
}
参考:
- 7. 整数反转——解析一
- 【leetcode】Reverse Integer整数反转----Java代码实现
- INT_MAX和INT_MIN注意事项
- Integer的MIN_VALUE
- 关于JAVA的Scanner(System.in)循环输入的一些问题与解决
- java怎么循环输入数字,然后按回车就知道跳出循环?