题目
  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怎么循环输入数字,然后按回车就知道跳出循环?