个人主页:Lei宝啊
愿所有美好如期而遇
本题我们使用异或,先用0异或整个数组,结果就是两个只出现一次的整数的异或,之后我们再遍历数组,并且每次下标加二,如果相邻数据不同,我们取本下标的数据,然后用他去异或我们之前的异或,最后我们插入并返回这两个数。
class Solution {
public:
    vector<int> singleNumber(vector<int>& nums) 
    {
        sort(nums.begin(),nums.end());
        vector<int> v;
        int num = 0;
        for(int i=0; i<nums.size(); i++)
        {
            num ^= nums[i];
        }
        for(int i=0; i<nums.size();)
        {
            if(nums[i] != nums[i+1])
            {
                v.push_back(nums[i]);
                v.push_back(num^nums[i]);
                return v;
            }
            else
            {
                i += 2;
            }
        }
        return v;
    }
}; https://leetcode.cn/problems/single-number-iii/
https://leetcode.cn/problems/single-number-iii/