执行 int x = Integer.MAX_VALUE + 1;
返回最小的负数。同理可得最大的正数。
如果执行 (Integer.MIN_VALUE + 1000) * 1000, 会得到 1000000。
又执行:(Integer.MIN_VALUE + 1000) * 459,得到 -2147024648。什么玩意。超范围不可控啊!
有这样一道题,整数反转。
输入: 123 输出 321 输入 -123 输出 -321, 如果反转后超出int范围,返回0。
把代码记下来,一看便知:
class Solution {
public int reverse(int x) {
int ret = 0;
while(x != 0) {
int pop = x % 10;
if (ret > Integer.MAX_VALUE / 10 || (ret == Integer.MAX_VALUE / 10 && pop > 7)) return 0;
if (ret < Integer.MIN_VALUE / 10 || (ret == Integer.MIN_VALUE / 10 && pop < -8)) return 0;
ret = ret * 10 + pop;
x /= 10;
}
return ret;
}
}