python二进制的位运算符

位运算符在刷leetcode和某些极端情况下偶尔会用到。

这里,我用python做一个演示,主要涉及与运算符(&),或运算符(^),进位运算符(<<)

1.与运算符(&)

只有当两个位数相同且都为1时才为1

1&1
#输出为:1

1&0
#输出为:0

0&0
#输出为:0

1&2
#输出为:0

(因为2在二进制下为10,10与1没有相同的位数返回0)

2.或运算符(^)

两个位数不同才为1,见之前的文章(https://blog.csdn.net/weixin_44731100/article/details/89156141

3.进位运算符(<<)

和十进制一样,用于进位

1<<1
#1向前进一位应该是二进制的10,即为2.所以输出为2

1<<2
#1向前进二位应该是二进制的100,即为4,所以输出为4

了解了以上原理后,针对面试题:写一个函数求两数之和,要求函数内不得使用加减乘除四则运算。

def add(a,b):
    while b != 0:
        #先计算各个位上不同的位数
        a = a^b
        # 对于两个数字位上都是1的情况进行进位,并进一步相加
        b = (a&b)<<1
    return a

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值