LeetCode hoot 100 -- 缺失的第一个正整数

本题取自LeetCode hoot 100 题号41 缺失的第一个正整数

一 题目概述

给定一个无序的整数数组 nums ,请你找出其中没有出现的最小的正整数

例:nums=1,3,4,没有出现的最小正整数为 2

请你实现时间复杂度为 O(n) 并且只使用常数级别额外空间的解决方案er

二 思路解析

要找到没有出现的最小正整数,正常的思路应该是先排序再找出未出现的元素。然而在此我们可以利用map<int,bool>结构,先遍历nums数组,记录元素出现情况,再从map中找出第一个没有被标记为bool的元素。代码如下:

然而可以看到,题目要求使用常数级别额外空间。既然无法利用map省去排序过程,我们只能原地进行排序。遍历所有元素,并将其放到自己该待的位置 swap(numsi, numsnums\[i-1]);

三 代码解析

map:

cpp 复制代码
class Solution {
public:
    int firstMissingPositive(vector<int>& nums) {
        unordered_map<int, bool> mp;
        // 遍历nums,记录正整数的出现情况
        for (int x : nums) {
            if (x > 0) mp[x] = true;
        }
        // 从1开始遍历,找到第一个未被标记为true的元素,即为答案
        int i = 1;
        while (mp.count(i)) {
            i++;
        }
        return i;
    }
};

swap:

cpp 复制代码
class Solution {
public:
    int firstMissingPositive(vector<int>& nums) {
        int n = nums.size();
        
        // 把每个数放到正确位置
        for (int i = 0; i < n; ++i) {
            // 只有数字在 1~n 范围内,且不在正确位置时才交换
            // 注,此处需要循环,而不只是if判断,因为如果向后置换往后不会遍历到被置换的元素,其也                  无法回到自己正确的位置
            while (nums[i] > 0 && nums[i] <= n && nums[nums[i]-1] != nums[i]) {
                swap(nums[i], nums[nums[i]-1]);
            }
        }
        
        // 第二步:找第一个不满足 nums[i] == i+1 的位置
        for (int i = 0; i < n; ++i) {
            if (nums[i] != i + 1) {
                return i + 1;
            }
        }

        // 全部都正确,返回 n+1
        return n + 1;
    }
};

感谢阅读

相关推荐
leo__5208 分钟前
小波特征与模糊支持向量机(FSVM)的脑电信号分类方法
算法·支持向量机·分类
wabs66612 分钟前
关于动态规划【纯粹的0-1背包需要思考的问题】
算法·动态规划
小小编程路14 分钟前
字符串转数字时,可能会遇到哪些问题?
java·开发语言·算法
rit843249929 分钟前
MATLAB近红外光谱预处理:平滑与求导(MSV方法)
数据结构·算法·matlab
蚂蚁数据AntData34 分钟前
从ChatBI到业务记忆:重新定义数据智能的生产力边界
大数据·网络·数据库·人工智能·算法
_日拱一卒35 分钟前
LeetCode:22括号生成
算法·leetcode·职场和发展
cfm_291436 分钟前
JVM垃圾收集算法与收集器深度解析
jvm·测试工具·算法·性能优化
郝学胜_神的一滴1 小时前
干货版《算法导论》09:让哈希表稳如泰山的终极解法
数据结构·算法
CC数学建模1 小时前
2026年第十六届APMCM 亚太地区大学生数学建模竞赛(中文赛项)赛题C题:创业社区规划与资源配置优化问题完整思路、代码、模型、文章,全网首发高质量分享!
python·算法·数学建模
徐小夕1 小时前
我们放弃了单Agent方案:HiCAD 3.0 用 Harness 做多Agent编排,把3D建模的准确率提升了30%
前端·算法·github