首页 > 编程语言 > 详细

Leetcode 268.缺失数字 By Python

时间:2018-09-23 12:30:19      阅读:155      评论:0      收藏:0      [点我收藏+]

给定一个包含 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

原文:https://www.cnblogs.com/MartinLwx/p/9692077.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!