(C++)只出现一次的数字III--异或

 个人主页:Lei宝啊 

愿所有美好如期而遇


力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://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. (52)出现数字III

    2023-12-12 10:30:05       58 阅读
  2. 力扣-260. 出现数字 III

    2023-12-12 10:30:05       46 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-12 10:30:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-12 10:30:05       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-12 10:30:05       82 阅读
  4. Python语言-面向对象

    2023-12-12 10:30:05       91 阅读

热门阅读

  1. Python高级算法——回溯法(Backtracking)

    2023-12-12 10:30:05       56 阅读
  2. 微信小程序实现图片上传到服务器

    2023-12-12 10:30:05       58 阅读
  3. CentOS修改SSH端口号和禁止root用户直接登录

    2023-12-12 10:30:05       65 阅读
  4. 构建自定义领域知识图谱的简易方法(Python)

    2023-12-12 10:30:05       63 阅读
  5. vue3+TypeScript自定义指令:长按触发绑定的函数

    2023-12-12 10:30:05       62 阅读
  6. C语言中常用的库函数和头文件

    2023-12-12 10:30:05       53 阅读
  7. 微信小程序九宫格布局,轮播图

    2023-12-12 10:30:05       64 阅读
  8. eventBus父组件$emit一次子组件多次收到¥

    2023-12-12 10:30:05       71 阅读