题目描述:
给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。
如果反转后整数超过 32 位的有符号整数的范围 [−231, 231 − 1] ,就返回 0。
示例:
思路:
需要注意的是 int 的有效数小于2的31次方的。需要先用 long 型进行。注意!!!而且有些数字可能是合法范围内的数字,但是反转过来就超过范围了。
代码:
昨晚力扣崩了 睡醒了
class Solution {
public int reverse(int x) {
long n = 0;
while(x != 0){
n = n * 10 + x % 10;
x=x/10;
}
if((int)n==n){
return (int)n;
}else{
return 0;
}
}
}