Leetcode 268.缺失数字 By Python

Posted MartinLwx

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Leetcode 268.缺失数字 By Python相关的知识,希望对你有一定的参考价值。

给定一个包含 0, 1, 2, ..., nn 个数的序列,找出 0 .. n 中没有出现在序列中的那个数。

示例 1:

输入: [3,0,1]
输出: 2

示例 2:

输入: [9,6,4,2,3,5,7,0,1]
输出: 8

说明:
你的算法应具有线性时间复杂度。你能否仅使用额外常数空间来实现?


思路

因为给定的序列也是从0开始,所以可以进行排序,比较索引和索引对应的值,如果两个不等于说明就确实一个值了,还要注意一个情况是,没出现的数字是n

代码

class Solution(object):
    def missingNumber(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        nums.sort()
        for i in range(len(nums)):
                if i != nums[i]:
                    return i
                if i == len(nums)-1:
                    return len(nums)

Ps.或者可以比较未缺失情况下的值和给定的序列的值的差就可以找到缺失数字

return len(nums)*(len(nums)+1)//2 - sum(nums)

以上是关于Leetcode 268.缺失数字 By Python的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode 第268题 缺失数字

LeetCode 268. Missing Number (缺失的数字)

[LeetCode] 268. Missing Number 缺失的数字

LeetCode Algorithm 268. 丢失的数字

力扣-268.缺失数字 题解

268. 缺失数字