在刷题的过程中,遇到了一道题。
其题目是
现在有一个整数类型的数组,数组中素只有一个元素只出现一次,其余的元素都出现两次。
注意:
你需要给出一个线性时间复杂度的算法,你能在不使用额外内存空间的情况下解决这个问题么?
这么一道题,我是绞尽脑汁也没想出来。最后去看了看别人的解法,发现自己还是没办法看懂。
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
如果你看到这里还没有理解上面的题为什么最终能够得到单独的一个数的话,那就可以这么想,将异或想成加法减法,每异或一个新值就是在原先的基础上加上那个值,然后等待相同的数去减去这个值。