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

题目

思路

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

如果要符合题目要求的O(N) O(1)的话,还是看了视频讲解,原来是把下标作为天然的哈希标签去做,每个i-1的位置应该放的是i,如果不是,就试图将现在的这个位置上的数字与该在这个位置上的数字交换(可能存在需要多次交换的情况,所以后续代码这一部分是用的while循环而不是一次if)。在原地交换完成后,对这个尽可能有序的数组进行历,如果哪一个位置的数字不满足numsi==numsnums\[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;
}

结果

相关推荐
凌波粒12 分钟前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle12 分钟前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
浦信仿真大讲堂34 分钟前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件
点云侠44 分钟前
PCL 生成三棱锥点云
c++·算法·最小二乘法
兰令水1 小时前
leecodecode【面试150】【2026.6.13打卡-java版本】
java·算法·leetcode
临沂堇1 小时前
刷题日志 | Leetcode Hot 100 哈希
算法·leetcode·哈希算法
玉小格1 小时前
一次关于Python的总结
算法
ychqsq1 小时前
54.新芽
经验分享·职场和发展
伊甸31 小时前
从企业级项目学敏感词过滤:DFA算法与双层缓存实战
java·算法·缓存
bIo7lyA8v2 小时前
算法中的随机化思想及其复杂度收益评估的技术8
算法