整数反转python

  • Post author:
  • Post category:python




一、题目描述

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

如果反转后整数超过 32 位的有符号整数的范围 [−2

31

, 2

31

− 1] ,就返回 0。




二、方法一

字符串法,利用python的切片功能实现整数反转

代码如下:

def reveres(x):
    str_x = str(x)
    if x < 0:
        str_x = str_x[:0:-1]
        res = -int(str_x)

    else:
        str_x = str_x[::-1]
        res = int(str_x)
    if res > 2**31-1 or res < -2**31:
       	return 0
    return res



三、方法二

整数翻转法,我们只要拿到数的末尾就好,以2645为例,将2645取模得5,然后将2645除10得到264,将264取模得4,以此取下去,最后可得答案。

代码如下:

def reveres(x):
    y,res = abs(x),0
    p =2**31-1 if x>0 else 2**31
    while y!=0:
        res = res*10+y%10
        if res>p:
            return 0
        y //=10 #//= 取整除赋值运算符 c //= a 等效于 c = c // a
    return res if x>0 else -res
print(reveres(2645))
print(reveres(-2645))

运行结果:

5462
-5462



版权声明:本文为weixin_37791679原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。