Reverse Integer
Reverse digits of an integer.
Example1: x = 123, return 321
Example2: x = -123, return -321
Solution1
- 像这种有可能会超出数据类型范围的情况,一般有两种比较好的解决办法:一种是用一个可以表示更大的数据类型,比如这里用long类型;另一种是用字符串去模拟大数,这种方法能够应对更大规模的数。
- 不用考虑超出范围后,这道题便变得非常简单了。如下:
public class Solution {
public int reverse(int x) {
long result = 0L;
boolean flag = false;
if(x<0){
flag = true;
x *= -1;
}
while(x!=0){
result = 10*result+(x%10);
x /= 10;
}
if(flag) result *= -1;
if(result<Integer.MIN_VALUE||result>Integer.MAX_VALUE) return 0;
return (int)result;
}
}
- 当然,也可以对负数不做任何处理直接使用也可以,这样一来代码更加的简单易懂。如下:
public class Solution {
public int reverse(int x) {
long result = 0L;
while(x!=0){
result = 10*result+(x%10);
x /= 10;
}
if(result<Integer.MIN_VALUE||result>Integer.MAX_VALUE) return 0;
return (int)result;
}
}
Solution2
- 针对这道题,也有一种方法可以不用解法一中的用一个更大范围的数去表示,而是直接在运行的时候就判断我即将要产生的数是否超出范围了, 如果在这个过程中,即将要产生的数超出范围了,那么可以直接返回0,代码如下:
public class Solution {
public int reverse(int x) {
int result = 0;
boolean flag = false;
if(x<0){
flag = true;
x *= -1;
}
while(x>0){
if(result>Integer.MAX_VALUE/10||result*10>Integer.MAX_VALUE-x%10) return 0;//前一个判断不能用result*10>Integer.MAX_VALUE
result = 10*result + x%10;
x /= 10;
}
return flag?-1*result:result;
}
}
- 但是像这种方法,一般除非特殊要求不建议使用,因为没有解法一来得直观易懂,并且比较容易出错。