题目:
Reverse digits of an integer.
Example1: x = 123, return 321
Example2: x = -123, return -321
意思就是把一个数反转过来,恩,是一道非常简单的题目,但是有个小坑,栽坑里好一会儿。
原来的答案如下:
class Solution {
public:
int reverse(int x) {
if (x == 0)return 0;
int abs_x = x>0 ? x : -x;
int tmp = 0;
while (abs_x / 10 > 0)
{
tmp *= 10;
int mod = abs_x % 10;
abs_x /= 10;
tmp += mod;
}
tmp *= 10;
tmp += abs_x;
return x>0 ? tmp : -tmp;
}
};
- 然后坑就来了,对一个翻转后的数值大于int类型所能表达的范围(-2147483648——-2147483647)的时候。比如1534236469
反转后是9646324351远远大于2147483647,而9646324351的二进制表示如下 10 00111110111101110011101001111111
这里最后整数只取低32位,也就是00111110111101110011101001111111,换成十进制也就是1056389759。
解决办法,根据leetcode上的错误提示,它期望在越界后,返回一个0
于是这里就投机取巧,把tmp的变量设为signed long long,最后判断该值是否越界,如果越界,返回0,否则转换成int返回。代码如下
class Solution {
public:
int reverse(int x) {
if (x == 0)return 0;
int abs_x = x>0 ? x : -x;
signed long long tmp = 0;
while (abs_x / 10 > 0)
{
tmp *= 10;
int mod = abs_x % 10;
abs_x /= 10;
tmp += mod;
}
tmp *= 10;
tmp += abs_x;
signed long long ret= x>0 ? tmp : -tmp;
if (ret-2147483647>0 || ret+2147483648 <0) return 0;
return (int)ret;
}
};