Given an array of numbers nums
, in which exactly two elements appear only once and all the other elements appear exactly twice. Find the two elements that appear only once.
For example:
Given nums = [1, 2, 1, 3, 2, 5]
, return [3, 5]
.
Note:
- The order of the result is not important. So in the above example,
[5, 3]
is also correct. - Your algorithm should run in linear runtime complexity. Could you implement it using only constant space complexity?
Credits:
Special thanks to @jianchao.li.fighter for adding this problem and creating all test cases.
二进制数,正负数互换,则要把全部数码(包括符号位)都求反加1。
+5:0101
-5:1010+1 = 1011
+5 & -5 = 0001
代码如下:
public class Solution {
public int[] singleNumber(int[] nums) {
int diff = 0;
for (int num: nums) {
diff ^= num;
}
diff &= -diff;
int target1 = 0, target2 = 0;
for (int num: nums) {
if ((num & diff) == 0) {
target1 ^= num;
} else {
target2 ^= num;
}
}
return new int[]{target1, target2};
}
}