解题思路:
\qquad
这道题目明确要求了时间复杂度为O(N),空间复杂度为O(1),不然借助哈希表很容易能够在O(N)的空间复杂度下解决。特殊的要求只能特殊处理,解这道题只能记住异或这种较特殊的运算方式。
\qquad
异或是对二进制数进行位运算,相同为0,相异为1(0 ^ 0 = 0; 1 ^ 1 = 0; 0 ^ 1 = 1;
)。
\qquad
异或的运算性质包括:
\qquad
\qquad
1. 交换率:a ^ b = b ^ a
\qquad
\qquad
2. 结合率:(a ^ b) ^ c = a ^ (b ^ c)
\qquad
\qquad
3. 自反性:a ^ a = 0
,a ^ b ^ b = a
\qquad
\qquad
4. 其他性质:a ^ 0 = a
,a ^ 1 = a'
(a的补码)
\qquad 这道题正是利用了自反性的特点,由于只有一个元素出现一次,其余全部出现两次,只要将他们全部异或,出现两次的元素异或结果为0,而剩下目标元素与0的异或结果为其本身。
int singleNumber(vector<int>& nums) {
int target = 0;
for(int i = 0; i < nums.size(); i++)
{
target = target ^ nums[i];
}
return target;
}