优选算法_丢失的数字_位运算_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;
    }
};//位运算
相关推荐
akarinnnn3 分钟前
深入理解内存函数:原理、应用与优化
c语言·网络·数据结构·算法
Hua-Jay3 分钟前
OpenCV联合C++/Qt 学习笔记(二十四)----差值法检测移动物体、稠密光流法跟踪移动物体及稀疏光流法跟踪移动物体
c++·笔记·qt·opencv·学习·计算机视觉
一行代码一行诗++11 分钟前
for循环中的break和continue
数据结构·算法
Tisfy14 分钟前
LeetCode 3043.最长公共前缀的长度:哈希表(不转string)
算法·leetcode·散列表·题解·哈希表
代码中介商15 分钟前
排序算法完全指南(三):插入排序深度详解
算法·排序算法
曾阿伦17 分钟前
Linux 系统资源查看命令大全
linux·运维·服务器
郭老二18 分钟前
【C++】RPC:远程程序调用
c++·rpc
承渊政道19 分钟前
【贪心算法】(经典实战应用解析(六):整数替换、俄罗斯套娃信封问题、可被三整除的最⼤和、距离相等的条形码、重构字符串)
c++·算法·leetcode·贪心算法·排序算法·动态规划·哈希算法
全栈游侠19 分钟前
DRM驱动分析01 - 初始化
linux
宠..19 分钟前
VS Code SSH 远程连接 Ubuntu 并实现快速运行(C/C++示例)
java·运维·c语言·开发语言·c++·ubuntu·ssh