LeetCode Hot100 之 41 缺失的第一个正数

题目

思路

如果要用O(N) O(N)的话就比较简单,罐存储后从小到大遍历就行了。代码略。

如果要符合题目要求的O(N) O(1)的话,还是看了视频讲解,原来是把下标作为天然的哈希标签去做,每个i-1的位置应该放的是i,如果不是,就试图将现在的这个位置上的数字与该在这个位置上的数字交换(可能存在需要多次交换的情况,所以后续代码这一部分是用的while循环而不是一次if)。在原地交换完成后,对这个尽可能有序的数组进行历,如果哪一个位置的数字不满足nums[i]==nums[nums[i]-1],那么这个数字就是缺失的第一个正整数。下面这位的解释很通俗易懂,可以搭配这个视频一起看

代码

cpp 复制代码
int firstMissingPositive(vector<int>& nums) {
    int n = nums.size();
    for (int i = 0; i < n; i++) {
        while (nums[i] >= 1 && nums[i] <= n && nums[i] != nums[nums[i] - 1]) {//因为 swap 之后位置 i 的元素变成新值,这个新值可能还需要继续交换
            swap(nums[i], nums[nums[i] - 1]);
        }
    }
    for (int i = 0; i < n; i++) {
        if (nums[i] != i + 1) {
            return i + 1;
        }
    }
    return n + 1;
}

结果

相关推荐
sheeta19981 小时前
LeetCode 每日一题笔记 日期:2026.05.13 题目:1674. 使数组互补的最少操作次数
笔记·算法·leetcode
liulilittle1 小时前
TCP UCP v1.0:BBR 的非破坏性约束层
网络·c++·网络协议·tcp/ip·算法·c·通信
每天回答3个问题1 小时前
LeetCodeHot100|回溯算法、46.全排列、78.子集、17.电话号码的字母组合
算法·深度优先·回溯
YL200404261 小时前
038翻转二叉树
数据结构·leetcode
Liangwei Lin2 小时前
LeetCode 287. 寻找重复数
算法·leetcode·职场和发展
Daorigin_com2 小时前
道本科技三大系统形成的“合同—合规—法务”智能闭环!
科技·职场和发展·分类·服务发现·边缘计算·集成学习·敏捷流程
OCR_133716212753 小时前
护照OCR校验位技术解析:从算法逻辑到工程落地,筑牢证件核验安全线
人工智能·算法
Hello.Reader3 小时前
算法基础(十三)——随机算法为什么有时主动引入随机性
java·数据库·算法
老鱼说AI3 小时前
现代 LangChain 开发指南:从 LCEL 原理到企业级 RAG 与 Agent 实战
java·开发语言·人工智能·深度学习·神经网络·算法·机器学习
小许同学记录成长4 小时前
基于幅度形态与参数聚类的工作模式判别
python·算法·scikit-learn