Python逻辑右移与大数相乘问题

1. Python大数相乘

最近在murmurhash2从Java转Python时候遇到一个问题,int无限宽度,不会溢出。算法中需要用到了32位int的溢出来参与运算,但是python的int是不会溢出的,达到界限后会自己转为long。

解决方案

#这个函数可以得到32位int溢出结果,因为python的int一旦超过宽度就会自动转为long,永远不会溢出,有的结果却需要溢出的int作为参数继续参与运算
def int_overflow(val):
    maxint = 2147483647
    if not -maxint-1 <= val <= maxint:
        val = (val + (maxint + 1)) % (2 * (maxint + 1)) - maxint - 1
    return val

2. Python实现逻辑右移(无符号右移)

Java中
带符号右移 >>
无符号右移 >>>

算术右移需要考虑符号位,右移一位,若符号位为1,就在左边补1,;否则,就补0。即如果该数为正,则高位补0,若为负数,则高位补1;

逻辑右移就是不考虑符号位,右移一位,左边补零即可。即若该数为正,则高位补0,而若该数为负数,则右移后高位同样补0

负数:r = -20 >> 2

-20 的二进制原码 :1001 0100

-20 的二进制反码 :1110 1011

-20 的二进制补码 :1110 1100

右移两位后的补码:1111 1011

反码:1111 1010

原码:1000 0101

结果:r = -5
负数: r = -20 >>> 2

注:以下数据类型默认为int 32位

-20:源码:10000000 00000000 00000000 00010100

反码:11111111 11111111 11111111 11101011

补码:11111111 11111111 11111111 11101100

右移:00111111 11111111 11111111 11111011

结果:r = 1073741819

Python代码实现:
结合第一个函数实现的大数相乘

def unsigned_right_shitf(n,i):
    # 数字小于0,则转为32位无符号uint
    if n < 0:
        n = ctypes.c_uint32(n).value
    # 正常位移位数是为正数,但是为了兼容js之类的,负数就右移变成左移好了
    if i < 0:
        return -int_overflow(n << abs(i))
    #print(n)
    return int_overflow(n >> i)```

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值