优选算法_丢失的数字_位运算_C++

一.题目解析

算法1:哈希表

我们要找到一个没有的数字,先把nums存入hash表中,对比缺失的数字是哪个

代码实现

cpp 复制代码
class Solution {
public:
    int missingNumber(vector<int>& nums) {
        int n=nums.size();
        unordered_map<int,int>hash(n);
        int count=0;
        for (int num : nums) //将数组存入哈希表
        {
            hash[num] = true;
        }
        for(int i=0;i<=n;i++)
        {
            if(!hash.count(i))return i;
        }
        return -1;
    }
};

算法优化:在对比hash表的时候可以使用二分查找

算法优化:

cpp 复制代码
class Solution {
public:
    int missingNumber(vector<int>& nums) {
        int n=nums.size();
        unordered_map<int,int> hash(n);
        for(int num:nums)
        {
            hash[num]=1;
        }
        int left=0,right=n;
        while(left<right)
        {
            int mid=left+(right-left)/2;
            if(hash.count(mid))left=mid+1;
            else right=mid;
        }
        return left;
    }
};

算法2:高斯求和

缺失的数字是在一个连续相邻的即0~n中,显然和减去数组和即是结果

代码实现:

cpp 复制代码
class Solution {
public:
    int missingNumber(vector<int>& nums) {
        int n=nums.size();
        int sum=0;
        for(int i=0;i<n;i++)
        {
            sum+=nums[i];
        }
        int sum1=(0+n)*(n+1)/2;
        int ret=sum1-sum;
        return ret;
    }
};//高斯求和

算法三:位运算

^(异或)的性质是"消消乐"即a^a=0,所以我们异或上一个连续的数组,相同的消除,留下的即是结果\

代码实现:

cpp 复制代码
class Solution {
public:
    int missingNumber(vector<int>& nums) {
        
        int ret=0;
        int n=nums.size();
        for(int i=0;i<n;i++)
        {
            ret^=nums[i];
        }
        for(int i=0;i<=n;i++)
        {
            ret^=i;
        }
        return ret;
    }
};//位运算
相关推荐
复杂网络3 小时前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
orion5715 小时前
Missing Semester Class1:course overview and introduction of shell
linux
apocelipes17 小时前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
HjhIron19 小时前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩20 小时前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
用户1204872216121 小时前
Linux驱动编译与加载
linux·嵌入式
触底反弹1 天前
🧠 搞懂 Token,才算真正入门大模型——从分词原理到 Embedding 语义实战
javascript·人工智能·算法
vivo互联网技术1 天前
ICLR 2026 | 基于后验采样的图像恢复方法LearnIR:人脸去阴影、去雾
人工智能·算法·aigc
浮生望1 天前
JS字符串与回文算法:从包装类到双指针的面试进阶之路
javascript·算法
用户805533698031 天前
Input 子系统架构:Core、Handler、Driver 三层是怎么协作的
linux·嵌入式