(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;
    }
};
相关推荐
肆忆_28 分钟前
Day 02|控制块分离架构:Boost 风格 shared_ptr 骨架落地
c++
lightqjx1 小时前
【C++】C++11 常见特性
开发语言·c++·c++11
tankeven1 小时前
HJ92 在字符串中找出连续最长的数字串
c++·算法
艾莉丝努力练剑1 小时前
【Linux:文件】进程间通信
linux·运维·服务器·c语言·网络·c++·人工智能
梦游钓鱼1 小时前
C++指针深度解析:核心概念与工业级实践
开发语言·c++
枫叶丹43 小时前
【Qt开发】Qt界面优化(五)-> Qt样式表(QSS) 子控件选择器
c语言·开发语言·数据库·c++·qt
xiaoye-duck3 小时前
《算法题讲解指南:优选算法-双指针》--01移动零,02复写零
c++·算法
额,不知道写啥。4 小时前
P5314 ODT(毒瘤树剖)
数据结构·c++·算法
Once_day4 小时前
GCC编译(4)构造和析构函数
c语言·c++·编译和链接
今儿敲了吗4 小时前
24| 字符串
数据结构·c++·笔记·学习·算法