位运算小总结_力扣136. 只出现一次的数字(一共五道题,带你入门位运算)

136. 只出现一次的数字

解题思路

位运算知识点:

1.关于异或:满足交换律 且 满足任何一个数和自己异或结果一定为0
且 任何一个数^0==它本身

2.取模

int a;
a%(2^n)  等价于  a&((2^n)-1)

3.判断奇偶数

a&1==0  是偶数
a&1==1  是奇数

4.两数交换

我们可以按照以下步骤进行交换:

1.使用异或运算得到a和b的异或值:c = a ^ b。

2.使用异或运算得到a的新值:a = c ^ a。

3.使用异或运算得到b的新值:b = c ^ b。

这样,a和b的值就被成功交换了。

这个方法的原理在于异或运算的一些性质:任何数与自己的异或值为 0 0 0 a a a ^ a a a = 0 0 0),任何数与 0 0 0的异或值为它本身( a a a ^ 0 0 0 = a a a),异或运算满足交换律和结合律。因此,通过两次异或运算,我们可以得到原来的值,实现了交换。

5. X X X= X X X&( X X X- 1 1 1) 可以清除最低位的1
比如:

int x = 21;//0001 0101
int count =0;//记录有几个一
while(x!=0){
	x=x&(x-1);
	count++;
}

/*在比如说:
判断3中的1:=>  换算成二进制就是 x=011
while(x不为0){
             //代码执行顺序=>          
	x=x&(x-1);//x = 011 & (010) =>010          //x = 010 & 001   =>000             //退出
	count++;  //1                              //2
}
*/

下面这个题也颇有启发
以下几个题,都是我写好的题解,大家去看一下,希望去大家有帮助!

6033. 转换数字的最少位翻转次数
461. 汉明距离
338. 比特位计数
762. 二进制表示中质数个计算置位

代码

class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int result= 0;
        for(int num:nums){
            result =result ^ num;
        }
        return result;
    }
};
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

踏过山河,踏过海

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值