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;
}

结果

相关推荐
rgb2gray2 小时前
论文详解:基于POI与出租车轨迹的城市多中心结构静态-动态多重分形特征
人工智能·python·算法·机器学习·数据分析·可解释
Zarek枫煜2 小时前
[特殊字符]栈(Stack)原理详解 \+ Zig / C3 双语言实现
c语言·单片机·嵌入式硬件·算法
jz_ddk2 小时前
[实战] CIC滤波器设计与实现
人工智能·算法·机器学习·数字信号处理·cic滤波器
Sakinol#2 小时前
Leetcode Hot 100 ——多维动态规划
算法·leetcode·动态规划
xsyaaaan2 小时前
leetcode-hot100-二叉树
数据结构·leetcode
XZXZZX2 小时前
ATCODER ABC 450 C题解
c++·算法·ccf csp
堕2742 小时前
JavaEE初阶——《多线程--. 多线程带来的的⻛险-线程安全 (重点)》
java·算法·java-ee
像素猎人2 小时前
差分数组【自用笔记】【c++】
c++·笔记·算法