题目

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);
        }
    }
}

参考:

  1. 7. 整数反转——解析一
  2. 【leetcode】Reverse Integer整数反转----Java代码实现
  3. INT_MAX和INT_MIN注意事项
  4. Integer的MIN_VALUE
  5. 关于JAVA的Scanner(System.in)循环输入的一些问题与解决
  6. java怎么循环输入数字,然后按回车就知道跳出循环?