(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;
    }
};
相关推荐
wljy11 天前
二、静态库的制作和使用
linux·c语言·开发语言·c++
道剑剑非道1 天前
FFmpeg 6.0 实战:用 C++ 封装摄像头采集与 RTSP 推流
开发语言·c++·ffmpeg
光电笑映1 天前
从环境变量到进程虚拟地址空间——Linux 内存管理的底层脉络
linux·服务器·c++·c
sparEE1 天前
c++字符串和自定义字面量
开发语言·c++
蜡笔小马1 天前
03.C++设计模式-原型模式
c++·设计模式·原型模式
神仙别闹1 天前
基于QT(C++)实现线性表的建立、插入、删除、查找等基本操作
java·c++·qt
salipopl1 天前
C/C++ 中 volatile 关键字详解:原理、作用与实际应用
开发语言·c++
张赫轩(不重名)1 天前
图论3:连通性问题(复杂度均为 O(N + M) )
c++·算法·图论·拓扑学
AIminminHu1 天前
(让 C++ 程序长出大脑:从“语音遥控器”到具身智能 Agent 的进化之路)------OpenGL渲染与几何内核那点事------(二-1-(15))
开发语言·c++·agent·具身智能
君义_noip1 天前
CSP-J 2025 入门级 第一轮(初赛) 完善程序(1)
c++·算法·信息学奥赛·csp 第一轮