【?异或】LeetCode 260. Single Number III

LeetCode 260. Single Number III

Solution1:
博客转载自:http://www.cnblogs.com/grandyang/p/4741122.html
这道题其实是很巧妙的利用了Single Number 单独的数字的解法,因为那道解法是可以准确的找出只出现了一次的数字,但前提是其他数字必须出现两次才行。而这题有两个数字都只出现了一次,那么我们如果能想办法把原数组分为两个小数组,不相同的两个数字分别在两个小数组中,这样分别调用Single Number 单独的数字的解法就可以得到答案。那么如何实现呢,首先我们先把原数组全部异或起来,那么我们会得到一个数字,这个数字是两个不相同的数字异或的结果,我们取出其中任意一位为‘1’的位,为了方便起见,我们用 a &= -a 来取出最右端为‘1’的位,然后和原数组中的数字挨个相与,那么我们要求的两个不同的数字就被分到了两个小组中,分别将两个小组中的数字都异或起来,就可以得到最终结果了,参见代码如下:
根据某一二进制位是否是1,把整数分成两组(不同的数字不同组)
之前在哪里见过相似的处理方法??

class Solution {
public:
    vector<int> singleNumber(vector<int>& nums) {
        #数组中的所有数的异或结果
        int diff = accumulate(nums.begin(), nums.end(), 0, bit_xor<int>());
        #负数的二进制是其绝对值二进制的反码加1得到的,一个正数和其相反数按位相交,会得到最右侧bit位1
        diff &= -diff;
        vector<int> res(2, 0);
        for (auto &a : nums) {
            if (a & diff) res[0] ^= a;
            else res[1] ^= a;
        }
        return res;
    }
};

你可能感兴趣的:(LeetCode练习题)