力扣hot100(17) 缺失的第一个正数

**破题的核心性质:**对于长度为n的数组,缺失的最小整数,一定在[1,n+1]这个区间里。

原因:最好情况:数组里刚好包含了所有的正整数,那缺失的最小正整数一定是n+1;

其他情况,只要1-n里有任意一个数没出现,那缺失的最小正整数那一定就是这个没出现的数。

置换法:

核心思想:既然答案在1--n里,我们把每个在[1,n]范围内的数字,放到它本应该在的位置上。比如,数字x本该在的位置是数组下标x-1。等所有的数字都归位,我们只需要遍历一遍数组:第一个下标i里的数不等于i+1的位置,那么i+1就是缺失的最小正整数。如果所有的位置都完全匹配,说明1--n都有,答案就是n+1;

cpp 复制代码
class Solution {
public:
    int firstMissingPositive(vector<int>& nums) {
        //首先进行排序 放到和下角标对应的位置 1放到0

        int n = nums.size();
        for(int i = 0;i<n;++i){

            //数组的该数大于0 且 该数大小不超过n 且 (该数-1)这个下角标对应的数 不等于该数
            //在0-n范围内的才操作 否则就跳过
            while(nums[i]>0&& nums[i]<=n && nums[nums[i]-1]!=nums[i]){

                swap(nums[nums[i]-1], nums[i]); //不相等就交换
            }
        }
        //排序好后再遍历
        for(int i = 0;i<n;++i){
            if(nums[i]!=i+1){
                return i+1;
            }
        }

        //否则就都存在 返回n+1的值
        return n +1;
    }
};
相关推荐
Zevalin爱灰灰2 小时前
现代密码学 第二章——流密码【下】
算法·密码学
飞Link4 小时前
大模型长文本的“救命稻草”:深度解析 TurboQuant 与 KV Cache 压缩技术
算法
郝学胜-神的一滴5 小时前
深度学习优化核心:梯度下降与网络训练全解析
数据结构·人工智能·python·深度学习·算法·机器学习
Je1lyfish5 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
许彰午5 小时前
03-二叉树——从递归遍历到非递归实现
java·算法
Brilliantwxx5 小时前
【C++】 vector(代码实现+坑点讲解)
开发语言·c++·笔记·算法
NorburyL7 小时前
DPO笔记
深度学习·算法
老纪的技术唠嗑局8 小时前
深度解析 LLM Wiki / Obsidian-Wiki / GBrain:Agent 时代知识的“自组织”与“自进化”
大数据·数据库·人工智能·算法
小程故事多_8010 小时前
[大模型面试系列] 深度解析ReAct框架,大模型Agent的“思考+行动”底层逻辑
人工智能·react.js·面试·职场和发展·智能体
YXXY31310 小时前
模拟算法的介绍
算法