Leetcode 7 Reverse Integer

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;     
    }
}
  • 但是像这种方法,一般除非特殊要求不建议使用,因为没有解法一来得直观易懂,并且比较容易出错。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值