输入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
}
}
reverse1--使用INT相反 - 有result-- reverse2溢出 - 使用长反向 - 没有结果的溢出