【力扣hot100题】缺失的第一个正数(12)

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

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

示例 1:

复制代码
输入:nums = [1,2,0]
输出:3
解释:范围 [1,2] 中的数字都在数组中。

示例 2:

复制代码
输入:nums = [3,4,-1,1]
输出:2
解释:1 在数组中,但 2 没有。

示例 3:

复制代码
输入:nums = [7,8,9,11,12]
输出:1
解释:最小的正数 1 没有出现。

提示:

  • 1 <= nums.length <= 105
  • -231 <= nums[i] <= 231 - 1
cpp 复制代码
class Solution {
public:
    int firstMissingPositive(vector<int>& nums) {
        int n = nums.size();
        for (int i = 0; i < n; ++i) {
            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;
            }
        }
        return n + 1;
    }
};
相关推荐
炽烈小老头7 小时前
【每天学习一点算法 2026/03/20】单词搜索
学习·算法
旖-旎7 小时前
二分查找(山脉数组的峰顶索引)(5)
c++·算法·leetcode·二分查找·力扣·双指针
阿贵---7 小时前
单元测试在C++项目中的实践
开发语言·c++·算法
进击的小头7 小时前
第14篇:MPC控制案例——无人机高度控制
python·算法·无人机
2401_891482178 小时前
C++中的事件驱动编程
开发语言·c++·算法
sw1213898 小时前
C++与Rust交互编程
开发语言·c++·算法
Huyuejia8 小时前
self-attention代码
算法
2401_857918298 小时前
模板编译期机器学习
开发语言·c++·算法
独自破碎E8 小时前
【面试真题拆解】5秒内限10次HTTP接口访问,结合数据结构和算法说说你的思路
数据结构·http·面试
放飞自我的Coder8 小时前
【动态规划解题思路】
算法·动态规划