(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;
    }
};
相关推荐
视觉人机器视觉1 小时前
Visual Studio2022和C++opencv的配置保姆级教程
c++·opencv·visual studio
liulilittle1 小时前
C++ i386/AMD64平台汇编指令对齐长度获取实现
c语言·开发语言·汇编·c++
sun0077002 小时前
std::forward作用
开发语言·c++·算法
海棠玛卡3 小时前
C/C++内存管理
c++
虾球xz3 小时前
CppCon 2018 学习:THE MOST VALUABLE VALUES
开发语言·c++·学习
2401_881244405 小时前
牛客周赛99
c++
山登绝顶我为峰 3(^v^)38 小时前
如何录制带备注的演示文稿(LaTex Beamer + Pympress)
c++·线性代数·算法·计算机·密码学·音视频·latex
十五年专注C++开发10 小时前
CMake基础:条件判断详解
c++·跨平台·cmake·自动化编译
QuantumStack13 小时前
【C++ 真题】P1104 生日
开发语言·c++·算法
天若有情67313 小时前
01_软件卓越之道:功能性与需求满足
c++·软件工程·软件