LeetCode 268. Missing Number

栏目: 编程工具 · 发布时间: 7年前

内容简介:Given an array containing给定一个包含由于索引即为 0 到 n 的数,所以可以先对数组进行排序,然后遍历数组,依次比较每个数是否与其索引相等,如果不相等,则对应的索引即为缺失值。当然,还要注意处理最后一个数缺失的情况,因为遍历数组只能处理 0 到 n-1。
LeetCode 268. Missing Number 题解

题目描述

  • 英文:

Given an array containing n distinct numbers taken from 0, 1, 2, ..., n , find the one that is missing from the array.

  • 中文:

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

示例

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

题解

  • 题解 1

由于索引即为 0 到 n 的数,所以可以先对数组进行排序,然后遍历数组,依次比较每个数是否与其索引相等,如果不相等,则对应的索引即为缺失值。当然,还要注意处理最后一个数缺失的情况,因为遍历数组只能处理 0 到 n-1。

class Solution:
    def missingNumber(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        length = len(nums)
        nums.sort()  # 排序
        for i in range(length):  # 遍历数组,判断列表值是否与索引相等
            if nums[i] != i:  # 如果不相等,则索引即为缺失的数
                return i
        return nums[length - 1] + 1  # 处理缺失最后一个数的情况
  • 题解 2

首先计算 0 到 n 的和,然后用和减去数组元素的和,即可得到缺失的元素。

class Solution:
    def missingNumber(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        con = 0
        for i in range(len(nums)+1):	# 求和
            con += i
        return con - sum(nums)	# 得到缺失值

也可以直接使用公式计算和,然后减去数组元素的和,即可得到缺失的元素。

class Solution:
    def missingNumber(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        length = len(nums)          
        return int(length*(length+1)/2 - sum(nums))

以上所述就是小编给大家介绍的《LeetCode 268. Missing Number》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

创业头条

创业头条

[美]兰德尔•莱恩(Randall Lane)及《福布斯》杂志编辑部 / 孙莹莹 / 浙江人民出版社 / 2015-6 / 54.90

[内容简介] 全民创业的浪潮中,如何抓住共享经济带来的机遇?没有营收模式还一直烧钱的公司,如何赢得投资人的青睐?一轮死、二轮死、N轮死的魔咒下,怎样才能成功活下来?面对数十亿美元的收购要约,创始人究竟应该如何抉择?没有资金又不懂技术,是否就无法分享互联网创业的红利?《创业头条》一书将为你揭秘上述问题的答案。 阅读《创业头条》一书你会发现,在硅谷最新崛起的互联网亿万富豪身上,有这样一......一起来看看 《创业头条》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具