Python的第一个失误
为了解决这个问题,我们将遵循以下步骤-
设置i:=0并通过在所有数字之前加一个0来更新数组nums
对于范围从0到nums的i
nums[nums[i]]:=nums[i]
nums[i]:=nums[nums[i]]
而nums[i]>=0且nums[i]<nums的长度和nums[nums[i]]不是nums[i]-
num:=1
对于范围从1到nums的i
如果num=nums[i],则将num加1
返回数字
示例
让我们看下面的实现以更好地理解-
class Solution(object):
def firstMissingPositive(self, nums):
i = 0
nums = [0] + nums
for i in range(len(nums)):
while nums[i]>=0 and nums[i]<len(nums) and nums[nums[i]]!=nums[i]:
nums[nums[i]],nums[i] = nums[i],nums[nums[i]]
num = 1
for i in range(1,len(nums)):
if num == nums[i]:
num+=1
return num
ob = Solution()print(ob.firstMissingPositive([4,-3,1,-1]))输入项
[4,-3,1,-1]
输出结果
2
热门推荐
9 薛之谦祝福语简短
10 新年简短的英文祝福语
11 歌词祝福语高级文案简短
12 科研文案祝福语简短励志
13 新人结婚简短祝福语大全
14 老婆生日祝福语短句简短
15 鱼的内涵简短祝福语
16 老公生日祝福语简短好看
17 满月红包英文祝福语简短
18 二胎祝福语简短霸气