leetcode 41. 缺失的第一个正数

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

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

示例 1:

输入:nums = [1,2,0]

输出:3

示例 2:

输入:nums = [3,4,-1,1]

输出:2

示例 3:

输入:nums = [7,8,9,11,12]

输出:1

提示:

1 <= nums.length <= 5 * 105

-231 <= nums[i] <= 231 - 1

题目链接:链接

思路1,如果是在 [1,n] 范围内,就交换到对应的位置,时间复杂度为 O(n)

python 复制代码
class Solution:
    def firstMissingPositive(self, nums: List[int]) -> int:
        i = 0
        n = len(nums)
        while i < n:
            while nums[i] <= n and nums[i] >= 1 and nums[i] != i+1:
                temp = nums[i]-1
                ### 下一个在合适的位置,不交换
                if temp >= 0 and temp < n and nums[temp] == temp+1:
                    break
                ##### 注意, 这儿不能写成 nums[i], nums[nums[i]-1] = nums[nums[i]-1], nums[i]
                nums[i], nums[temp] = nums[temp], nums[i]
            i += 1
        for i in range(n):
            if nums[i] != i+1:
                return i+1
        return n+1
相关推荐
f***2411几秒前
Bug悬案:技术侦探的破案指南
算法·bug
Swift社区3 分钟前
LeetCode 472 连接词
算法·leetcode·职场和发展
Dream it possible!4 分钟前
LeetCode 面试经典 150_二分查找_搜索旋转排序数组(114_33_C++_中等)
c++·leetcode·面试
CoovallyAIHub10 分钟前
YOLO-Maste开源:首个MoE加速加速实时检测,推理提速17.8%!
深度学习·算法·计算机视觉
清铎13 分钟前
leetcode_day13_普通数组_《绝境求生》
数据结构·算法
hetao173383724 分钟前
2026-01-09~12 hetao1733837 的刷题笔记
c++·笔记·算法
过河卒_zh15667661 小时前
情感型AI被“立规矩”,AI陪伴时代进入下半场
人工智能·算法·aigc·生成式人工智能·算法备案
wefg11 小时前
【算法】动态规划
算法·动态规划
机器学习之心1 小时前
198种组合算法+优化TCN-Transformer+SHAP分析+新数据预测+多输出!深度学习可解释分析,强烈安利,粉丝必备!
深度学习·算法·transformer·shap分析·新数据预测
狐571 小时前
2026-01-12-LeetCode刷题笔记-1266-访问所有点的最小时间.md
笔记·算法·leetcode