136. 只出现一次的数字
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
异或运算(消消乐)
异或运算性质:
- a XOR 0 = a
- a XOR a = 0
- a XOR b XOR a = b XOR (a XOR a) = b 满足交换律和结合律
所以可以遍历nums,从第一个数开始异或运算,到最后,出现了两次的值会抵消,只会剩下那个solo
class Solution {
public int singleNumber(int[] nums) {
int n = 0;
for(int num : nums){
n ^= num;
}
return n;
}
}