【LeetCode136】只出现一次的数字(不能用哈希,用位运算-异或)

1.题目

在这里插入图片描述

2.思路

如果没有空间复杂度的要求,那肯定用哈希了,但是这题要求“线性时间复杂度、常数空间复杂度”,不使用额外空间。
根据具体题目特性:除了那个只出现1次的元素,其他元素都是出现2次的——2次!2次!!,“异或”运算就是“二进制比较,相同为0,不同为1”,而其实“异或”也有交换律和结合律

若将所有出现2次的元素“异或”起来得到二进制的一坨0,最后再和出现1次的元素“异或”运算(某数和0异或还是该数)得到这个出现1次的元素。

【位运算】是一种“骚”操作,之前根据数字二进制下 1 的数目排序里的与运算a&=(a-1)实现去掉a的距离最右边最近的一个1,如a=10,则a&(a-1)=10&9=1010 & 1001=1000=8,即实现10的二进制1010的最右边的一个1去掉了。要积累这种做题技巧。

3.代码

class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int ans=nums[0];
        for(int i=1;i<nums.size();i++){
            ans^=nums[i];
        }
        return ans;
    }
};
  • 1
    点赞
  • 0
    收藏
  • 打赏
    打赏
  • 0
    评论

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:Age of Ai 设计师:meimeiellie 返回首页
评论

打赏作者

山顶夕景

小哥哥给我买个零食可好

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值