IT编程 > 开发语言 > .net

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

40人参与2020-07-07

【题目】

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

 

【题目解析】

飞机对号入座,原地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 是错误的!

 

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

您对本文有任何疑问!!点此进行留言回复

推荐阅读

猜你喜欢

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

07-07

LeetCode1498. 满足条件的子序列数目

07-07

使用队列在进程中的通信

07-07

Leetcode231. 2的幂

07-07

cs224n笔记05-探索词向量

07-07

PointNet++分类train.py

07-07

大家都在看

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

07-07

从Client应用场景介绍IdentityServer4(五)

12-27

curl: (7) Failed connect to IP:port; No route to host解决方案

07-15

ASP.NET学习笔记(五)委托

03-30

花样试用微软语音服务晓晓

04-12

记开发个人图书收藏清单小程序开发(九)Web开发——新增图书信息

06-26

两种查看EFCore生成Sql语句的方法

09-20

asp.net core 3.0 MVC JSON 全局配置

12-17

拓展阅读

热门评论