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
相关推荐
YXXY3132 小时前
模拟算法的介绍
算法
happymaker06263 小时前
简单LRU的实现(基于LinkedHashMap)
算法·leetcode·lru
会编程的土豆3 小时前
【数据结构与算法】空间复杂度从入门到面试:不仅会算,还要会解释
数据结构·c++·算法·面试·职场和发展
普通网友3 小时前
《算法面试必刷:15 个高频 LeetCode 题(附代码)》
算法·leetcode·面试
_深海凉_3 小时前
LeetCode热题100-搜索二维矩阵
算法·leetcode·矩阵
张槊哲3 小时前
C++ 进阶指南:如何丝滑地理解与实践多线程与多进程
开发语言·c++·算法
代码中介商4 小时前
C语言链表完全指南:从单节点到链表管理
c语言·算法·链表
小小de风呀4 小时前
de风——【从零开始学C++】(四):类和对象(下)
开发语言·c++·算法
aqiu1111114 小时前
[特殊字符]【算法日记 14】数论入门神题:最大公约数与最小公倍数的“乘积守恒定律”
算法
保卫大狮兄5 小时前
一文讲清:仓库管理最核心的10个公式
人工智能·算法·仓库管理