leetcode7 整数反转

给你一个 32 位的有符号整数 x ,返回 x 中每位上的数字反转后的结果。

如果反转后整数超过 32 位的有符号整数的范围 [−231,  231 − 1] ,就返回 0。

假设环境不允许存储 64 位整数(有符号或无符号)。

示例 1:

输入:x = 123
输出:321
示例 2:

输入:x = -123
输出:-321
示例 3:

输入:x = 120
输出:21
示例 4:

输入:x = 0
输出:0

提示:

-231 <= x <= 231 - 1

解题思路:本题目主要有两个问题:(1)  是如何将 数字 翻转 (2)在不允许采用64位整数的情况下,如何判断溢出。  问题(1)较容易解决,问题(2) 较麻烦。

自己本来想到采用将数字转换为字符串 翻转在转换为数字的方式,后来发现此方法较复杂。因此采用直接计算的方法。

有关溢出的问题:

首先  int类型的最大值和最小值分别为: -2147483648, 2147483647    只要小于-2147483648 或者大于2147483647   都叫溢出。 

我们可以提前一位判断, 对于大于2147483647的溢出。

借鉴别人的思路:

假设有1147483649这个数字,它是小于最大的32位整数2147483647的,但是将这个数字反转过来后就变成了9463847411,这就比最大的32位整数还要大了,这样的数字是没法存到int里面的,所以肯定要返回0(溢出了)。
甚至,我们还需要提前判断

上图中,绿色的是最大32位整数
第二排数字中,橘子的是5,它是大于上面同位置的4,这就意味着5后跟任何数字,都会比最大32为整数都大。
所以,我们到【最大数的1/10】时,就要开始判断了
如果某个数字大于 214748364那后面就不用再判断了,肯定溢出了。
如果某个数字等于 214748364呢,这对应到上图中第三、第四、第五排的数字,需要要跟最大数的末尾数字比较,如果这个数字比7还大,说明溢出了。

对于负数也是一样的

上图中绿色部分是最小的32位整数,同样是在【最小数的 1/10】时开始判断
如果某个数字小于 -214748364说明溢出了
如果某个数字等于 -214748364,还需要跟最小数的末尾比较,即看它是否小于8。

 

这里要注意另外一个问题: 需要注意的是要 在判断溢出时,要 先判断是否溢出 再在翻转的数字后面补最后一位

如果把 reverseNum = reverseNum*10 + temp; 放到   if ((reverseNum > 214748364)||( (reverseNum == 214748364)&&(temp > 7) ))前面。

那么会存在 -2147483412  被判断为0的情况,原因是在补上倒数第二位之后判断是不会溢出, 不会返回0 的,然而在 最后一次循环

补充上最后一位   后再判断 时,肯定会溢出。

因此,因此在补充最后一位之前做溢出判断,所以 reverseNum = reverseNum*10 + temp;要放到溢出判断的后面。

class Solution {
public:
    int reverse(int x) {
        int reverseNum = 0;


        while( x != 0)
        {
            int temp = x%10;
            if ((reverseNum > 214748364)||( (reverseNum == 214748364)&&(temp > 7) ))
            {
                return 0;
            }
            if ((reverseNum < -214748364)||( (reverseNum == -214748364)&&(temp < -8) ))
            {
                return 0;
            }
            reverseNum = reverseNum*10 + temp;
            x = x/10;  
        }
        return reverseNum;
    }
};

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值