(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;
    }
};
相关推荐
云泽8085 小时前
笔试算法 - 双指针篇(一):移动零、复写零、快乐数与盛水容器
c++·算法
小堃学编程5 小时前
【项目实战】基于protobuf的发布订阅式消息队列(4)—— 服务端
c语言·c++·vscode·消息队列·gtest·protobuf·muduo
小白学大数据6 小时前
解决 Python 爬虫被限制:延迟抓取指令深度解析
开发语言·c++·爬虫·python
会编程的土豆6 小时前
【复习】二分查找
数据结构·c++·算法
yuanpan7 小时前
Python 调用 DLL 动态库入门:Windows 下调用 C++ 与 C# 动态库完整示例
c++·windows·python
handler017 小时前
Linux: 基本指令知识点(3)
linux·服务器·c语言·开发语言·c++·笔记
wuminyu7 小时前
专家视角看Java线程生命周期与上下文切换的本质
java·linux·c语言·jvm·c++
云深麋鹿8 小时前
C++ | 容器list
开发语言·c++·容器·list
handler018 小时前
Linux 基本指令知识点(1)
linux·c++·笔记
hansel_sky8 小时前
题解-数字删除
c++·程序人生