位运算的简便方法

1. & 运算

1.1 例题

计算23 & 77的结果(结果为⼗进制)。

1.2 传统解法
转换为两个⼆进制数,逐位进⾏计算,最终再换算为⼗进制。
1.3 简单解法
思路: 瞪眼法将两个操作数都拆分为⼗进制的若⼲个 2 n 次⽅之和,然后判断哪些值是两个操作数 中都包含的部分(注意, 的逻辑就是表示共同拥有),相加即可。
其中, 4 1 是共有元素,所以 23 & 77 的结果就是 4 + 1 = 5

2. | 运算

2.1 例题

计算23 | 77的结果(结果为⼗进制)。

2.2 传统做法

将23、77转换成二进制,然后相应位置进行或运算

2.3 简单解法
或运算和与运算简单算法有相似逻辑,只不过将 交集运算 改为求 并集运算 即可。
注意: (二进制简单运算) 可以看得出来 64 + 16 + 8 + 4 + 2 + 1 这⼀组数就等于 127 - 32 = 95 。 因为 64 + 32 + 16 + 8 + 4 + 2 + 1 即为⼆进制中的 01111111 127 64 + 16 + 8 + 4 + 2 + 1 这个式⼦中只缺少了32,二进制为01011111(95)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值