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
热门推荐
10 祝女儿简短祝福语大全
11 大学新年祝福语简短创意
12 元旦适合的祝福语简短
13 朋友出远门祝福语简短
14 初六简短的祝福语
15 祝男孩生日祝福语简短
16 同事调离的祝福语简短
17 拜年红包的祝福语简短
18 妈妈生日祝福语简短励志