位运算相关

按位异或运算定义,

1 ^ 1=0

1 ^ 0=1

0 ^ 1=1

0 ^ 0=0

异或,就是“看看你们到底一样不一样。不一样就为1,一样就为0。”

满足交换率结合率

1.不用中间变量,交换ab的数值:


2.不能利用任何比较,返回ab中比较大的那个:

(图中右移31位得到的应该是符号位,sign 得到符号,a-b为正数0,sca为1,scb为0,负数sca为0,scb为1


方法1,a-b可能溢出。


ab符号相同时候,a-b不可能溢出。

不同时候difab为1,same为0,返回a,后面同理


3

利用交换率结合率,用一个变量不停异或即可,得到的最后的就是那个数字


4,布隆过滤器



它可以通过一个Hash函数将一个元素映射成一个位阵列(Bit array)中的一个点。这样一来,我们只要看看这个点是不是1就可以知道集合中有没有它了。

具体过程不详细解释。理解即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值