Leetcode刷题记录 · No.7 Reverse Integer

原题

Reverse digits of an integer.

Example1: x = 123, return 321
Example2: x = -123, return -321

注意事项

  • 需要考虑符号
  • 需要考虑末位0的数,如100,1200等
  • 需要考虑溢出情况,在本题中如果有溢出返回0

解题思路

  1. 取符号,再将原数取绝对值;全程对正数进行处理,最后返回结果时再考虑正负;
  2. 逐位循环,每次循环中有res = res * 10 + x % 10;x = x / 10; 其中结果用一个long存储,防止溢出的情况。
  3. 判断结果是否溢出,返回结果。

总结

这是一个比较简单的题目,只要注意几个细节就OK了。

源代码

class Solution {
public:
    int reverse(int x) {
        int sign; //记录正负
        long  res = 0;
        sign = (x > 0) ? 1 : (-1);
        x = abs(x);
        while (x)
        {
            res = res * 10 + x % 10;
            x = x / 10;
        }

        res = sign * res;
        if (res > INT32_MAX || res < INT32_MIN)//溢出
        {
            return 0;
        }

        return int(res);
    }
};

UPDATE 2016/10/21

有一种更简单的判断溢出的方法,而且不需要定义一个long的变量。代码如下:

class Solution {
public:
    int reverse(int x) {
        if(x == INT32_MIN)//注意INT_MIN的绝对值会出现问题,因为其绝对值大于INT_MAX,所以要对这一特例进行处理
            return 0;
        int sign; //记录正负
        int  res = 0;
        sign = (x > 0) ? 1 : (-1);
        x = abs(x);
        while (x)
        {
            if(res>INT32_MAX / 10 || (res==INT32_MAX/10 && res%10>7))
                return 0;
            res = res * 10 + x % 10;
            x = x / 10;
        }
        return sign*res;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值