(C++)只出现一次的数字III--异或

个人主页:Lei宝啊

愿所有美好如期而遇


力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/single-number-iii/

本题我们使用异或,先用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;
    }
};
相关推荐
LoveXming2 分钟前
Chapter14—中介者模式
c++·microsoft·设计模式·中介者模式·开闭原则
杨筱毅3 小时前
【C++】【常见面试题】最简版带大小和超时限制的LRU缓存实现
c++·面试
陌路204 小时前
C23构造函数与析构函数
开发语言·c++
_OP_CHEN5 小时前
C++进阶:(二)多态的深度解析
开发语言·c++·多态·抽象类·虚函数·多态的底层原理·多态面试题
金色熊族6 小时前
装饰器模式(c++版)
开发语言·c++·设计模式·装饰器模式
Dream it possible!6 小时前
LeetCode 面试经典 150_链表_旋转链表(64_61_C++_中等)
c++·leetcode·链表·面试
CS创新实验室9 小时前
典型算法题解:长度最小的子数组
数据结构·c++·算法·考研408
我有一些感想……9 小时前
浅谈 BSGS(Baby-Step Giant-Step 大步小步)算法
c++·算法·数论·离散对数·bsgs
j_xxx404_9 小时前
C++ STL:string类(3)|operations|string类模拟实现|附源码
开发语言·c++
Elias不吃糖11 小时前
Linux 环境适应 Day 1 全面笔记
linux·c++·笔记