问题描述:
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?
分析:做了single1,single2再来做这道题发现还是不会,将vector中的元素做异或之后,得到的是两个不同元素的异或值,即两个元素的信息混合在一起。
如何将二者分开,想了好久没想到办法。网友的介绍是利用两个元素的异或值(说明,要找的元素的对应位不同),利用这个特点将原有的序列分为两部分,这样,元素A和元素B分别在两个不同的序列里面了。
这里面还有一个很巧妙的地方是,使用n&(~(n-1))可以取出元素的最后一个1的位置。
代码如下:20ms
class Solution {
public:
vector<int> singleNumber(vector<int>& nums) {
int AxorB = 0;
for(int i = 0;i<nums.size();i++){
AxorB^=nums[i];
}
//取最后一个二进制位
int mask = AxorB & (~(AxorB-1));
int A = 0,B = 0;
for(int i = 0;i<nums.size();i++){
if(mask&nums[i])
A ^= nums[i];
else
B ^= nums[i];
}
return vector<int>({A,B});
}
};
本文探讨如何在数组中找到仅出现一次的两个元素,通过异或操作和位操作解决此问题,实现O(n)时间复杂度和O(1)空间复杂度。
&spm=1001.2101.3001.5002&articleId=47949037&d=1&t=3&u=f833c139992a42018d1b82b2770a7d80)
490

被折叠的 条评论
为什么被折叠?



