leetcode 7. 反转整数(python3)

题目描述

给定一个 32 位有符号整数,将整数中的数字进行反转。

示例 1:

输入: 123
输出: 321

示例 2:

输入: -123

输出: -321

示例 3:

输入: 120

输出: 21

注意:

假设我们的环境只能存储 32 位有符号整数,其数值范围是 [−2**31, 2**31 − 1]。根据这个假设,如果反转后的整数溢出,则返回 0.

int类型详解

使用python解题的话上述类型的话不用再考虑,也就是说,python解释器认为int类型不只有32位,所以在python中也就不存在溢出这个问题。因此python可以取巧,先将整数进行反转,然后判断反转之后的整数是否超越边界。

在其他的编程语言中,int一般被规定为32位有符号整数,因此,其所能表示的最大范围是被限定的,32位中第一位被拿来做符号位,只有剩下的31位能够表示数据。
因此,int类型下最大的数据表示为2147483647=2^31-1。其原码、反码、补码都相同如下:

0111 1111 1111 1111 1111 1111 1111 1111
因为32位中有一位符号位,因此只有31位能表示数据,那么好像int的最小数值就应该是-2147483647=-2^31-1。其原码、反码、补码如下

原码为1111 1111 1111 1111 1111 1111 1111 1111,

反码为1000 0000 0000 0000 0000 0000 0000 0000,

补码为1000 0000 0000 0000 0000 0000 0000 0001

所以最小的负数是-2147483647吗?错,不是。

在二进制中,0有两种表方法。

+0的原码为0000 0000 0000 0000 0000 0000 0000 0000,

-0的原码为1000 0000 0000 0000 0000 0000 0000 0000,

因为0只需要一个,所以把-0拿来当做一个最小的数-2147483648。

-2147483648的补码表示为1000 0000 0000 0000 0000 0000 0000 0000,在32位没有原码。

注意,这个补码并不是真正的补码,真正的补码是1 1000 0000 0000 0000 0000 0000 0000 0000,溢出。

所以带符号32位int类型整数为-2147483648~2147483647

解题代码

class Solution:
    def reverse(self, x):
        reverse_num=int(str(abs(x))[::-1])
        if reverse_num.bit_length() > 31:
            return 0
        else:
            return reverse_num if x > 0 else -reverse_num
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值