python使用位运算实现整数加法运算

位运算是二进制的一种基础运算,在生产中经常用来加密。下面是使用Python位运算来实现加法运算:

主要用到三个位运算符:异或^,和与&、左移位<<。对于异或,同位置数字不同则为1,相同则为0:

2^1 = 3  ==> 0010 ^ 0001 = 0011
2^2 = 0  ==> 0010 ^ 0010 = 0000
3^5 = 6  ==> 0011 ^ 0101 = 0110

对于与&,同时为1则为1,否则为0:

8&15 = 8 ==> 1000 & 1111 = 1000
10&5 = 0 ==> 1010 & 0101 = 0000
10&3 = 2 ==> 1010 & 0011 = 0010

左移位,进制的数量级增加:

2<<1 = 4 ==> 0010<<1 = 0100
6<<1 = 12 ==> 0110<<1 = 1100
1<<2 = 4 ==> 0001<<2 = 0100

对于任意数字相加,可以看成其二进制相加并移位的结果,例如:

2+1 = 3 ==> 0010+0001 = 0011
3+5 = 8 ==> 0011+0101 = 1000
1+1 = 2 ==> 0001+0001 = 0010

当位上满1相加时,则向前进位

所以可以得知,当相加的两个数二进制的同一个位置上数字不一样时(1和0或者0和1),这个位置的最终结果肯定是1,如果相同时(0和0或者0和1),这个位置的结果上肯定是0,在不考虑进位的情况时,恰好是个异或运算。

而进位则是如果两个数都为1,则进位,否则不进位,恰好是个与运算。则可以表示如下:

a + b = (a^b) + ((a&b)>>1)

可以验证一下:

12+15==(12^15)+((12&15)<<1) #True
123+321==(123^321)+((123&321)<<1) #True
12+150==(12^150)+((12&150)<<1) #True
199+23==(199^23)+((199&23)<<1) #True

所以可以定义一个函数sum,用Python表示如下:

def sum(a, b):
    return (a^b)+((a&b)<<1)

到这儿基本上就可以解决问题了,我们现在只选要把函数中的“+”号去掉即可,让sum一直迭代到b为0,因为如果b不为0则说明会有进位的情况存在,所以去掉“+”号进行迭代代码如下:

def sum(a, b):
    if b is 0:
        return a
    return sum(a^b,(a&b)<<1)

'''
#或者比较pythonic的写法:
def sum(a, b):
    return a if b is 0 else sum(a^b,(a&b)<<1)
'''

好了,到此sum函数就可以进行加法运算了。

你可能感兴趣的:(python)