(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;
    }
};
相关推荐
muzi_liii23 分钟前
认识哈希以及哈希表的模拟实现
c++·哈希算法
The Chosen One98532 分钟前
C++:类和对象(上)---镜中万象:C++类的抽象之境与对象的具体之象
开发语言·c++
zyx没烦恼42 分钟前
线程池&&单例模式
linux·开发语言·c++·单例模式
小王努力学编程2 小时前
【Linux网络编程】应用层协议HTTP(实现一个简单的http服务)
linux·服务器·网络·c++·网络协议·学习·http
是店小二呀2 小时前
【优选算法 | 滑动窗口】滑动窗口算法:高效处理子数组和子串问题
c++·算法
小破农3 小时前
C++篇——继承
c++·笔记
努力学习的小廉3 小时前
我爱学算法之—— 二分查找(上)
开发语言·c++·算法
wqfhenanxc4 小时前
Mixing C++ and Rust for Fun and Profit 阅读笔记
c++·笔记·rust
R-G-B4 小时前
【MFC】 VS2022打开低版本的MFC,双击.rc文件,DIalog加载失败,页面弹窗fatal error RC***:cannot open*****
c++·mfc·vs打开较早版本mfc·双击.rc文件·dialog加载失败·fatal error rc·cannot open
敲上瘾4 小时前
基于Tcp协议的应用层协议定制
linux·运维·服务器·网络·c++·网络协议·tcp/ip