LeetCode之7. Reverse Integer

题目:

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;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值