leetcode 数组独数问题

在刷题的过程中,遇到了一道题。
其题目是

现在有一个整数类型的数组,数组中素只有一个元素只出现一次,其余的元素都出现两次。
注意:
你需要给出一个线性时间复杂度的算法,你能在不使用额外内存空间的情况下解决这个问题么?

这么一道题,我是绞尽脑汁也没想出来。最后去看了看别人的解法,发现自己还是没办法看懂。

public static int singleNumber(int[] A) {
    int num = 0;
    for(int i=0;i<A.length;i++){
        num^=A[i];
    }
    return num;
}

因为在我的印象中,异或就是相同的两个数为0,不同的两个数为1,仅此而已。那为什么,这个代码能够在最后输出那个单独的数字呢?
在查看解答的过程中,有大佬提到了“0异或一个数为那个数本身”,并且我在一篇博客中发现异或可以用来做交换。我才发现既然0与任何数异或都为任何数,那些相同的两个数异或在一起之后会变为零,最终剩下的只有那个单独的数
我将这部分代码,以数组为[3,2,5,3,2]运行起来,并查看输出

3,1,4,7,5
第一步:0^3=0000^0011=0011         3
第二步:3^2=0011^0010= 0001        1
第三步:1^5=0001^0101 =0100        4
第四步:4^3=0100^0011= 0111        7
结果:7^2=0111^0010=0101           5

如果你看到这里还没有理解上面的题为什么最终能够得到单独的一个数的话,那就可以这么想,将异或想成加法减法,每异或一个新值就是在原先的基础上加上那个值,然后等待相同的数去减去这个值。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值