欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

【Leet-Code】41. 缺失的第一个正数

程序员文章站 2022-03-30 09:29:13
【题目】给你一个未排序的整数数组,请你找出其中没有出现的最小的正整数。【题目解析】飞机对号入座,原地O(N)解法!class Solution: def firstMissingPositive(self, nums: List[int]) -> int: for a in nums: #遍历每个座位,记当前坐着a号乘客 while 0

【题目】

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

【Leet-Code】41. 缺失的第一个正数

 

【题目解析】

飞机对号入座,原地O(N)解法!

class Solution:
    def firstMissingPositive(self, nums: List[int]) -> int:

        for a in nums: #遍历每个座位,记当前坐着a号乘客

            while 0<a<=len(nums) and a!=nums[a-1]:  #乘客a是正票但坐错了! 其座位被 ta=nums[a-1]占了

                nums[a-1], a = a, nums[a - 1]  # a和ta两人互换则a对号入座。此后ta相当于新的a,去找自己的座位(循环执行)

        #print(nums)

        for i in range(len(nums)):
            if i+1!=nums[i]:
                return i+1  #找到首个没有对号入座的nums[i]!=i+1

        return len(nums)+1  #满座,返回N+1

 

注意:

题解中:如果将:nums[a-1], a = a, nums[a-1] 换成 a, nums[a-1] = nums[a-1], a 是错误的!

【Leet-Code】41. 缺失的第一个正数

 

【Leet-Code】41. 缺失的第一个正数

本文地址:https://blog.csdn.net/wdh315172/article/details/107156953