的整数的反向位 - 类似的代码不同的输出

问题描述 投票:0回答:1

输入1534236469我得到2个不同的答案中均为反向1--是什么呢反向1这样做是错的?

/ ** *给定一个32位有符号整数,反向的整数的数字。 * *实施例1:* *输入:123输出:321实施例2:* *输入:-123输出:-321实施例3:* *输入:120输出:21注意:假设我们正在处理的环境中,其中*仅可能32位带符号整数的范围内存储的整数:[-231,231 * - 1]。对于这个问题的目的,假设你的函数返回0 *反转的整数溢出时。 * /

公共类ReverseInteger {

public static int reverse1(int x) {
    int multiplicationFactor = 1;

    if (x < 0) {
        multiplicationFactor = -1;
    }
    x = Math.abs(x);
    int reverse = 0;
    int remainder = 0;
    while (x > 0) {
        remainder = x % 10;
        x = x / 10;
        reverse = reverse * 10 + remainder;

    }

    if (reverse > Integer.MAX_VALUE || reverse < Integer.MIN_VALUE) {
        return 0;
    }

    return reverse * multiplicationFactor;

}

public static int reverse(int x) {
    long reverse = 0;
    boolean negative = x < 0;
    x = Math.abs(x);
    while (x > 0) {
        int y = x % 10;
        x = x / 10;
        reverse = reverse * 10;
        reverse = reverse + y;

    }
    if (negative) {
        reverse = -1 * reverse;
    }
    if (reverse > Integer.MAX_VALUE || reverse < Integer.MIN_VALUE) {
        return 0;
    }
    return (int) reverse;
}

public static void main(String[] args) {
    // TODO Auto-generated method stub
    reverse(1534236469);//output- 0
    reverse1(1534236469);//output- 1056389759
    // 2147483647

}

}

integer reverse
1个回答
0
投票

reverse1--使用INT相反 - 有result-- reverse2溢出 - 使用长反向 - 没有结果的溢出

© www.soinside.com 2019 - 2024. All rights reserved.