数组nums包含从0到n的所有整数,但其中缺了一个。请编写代码找出那个缺失的整数。你有办法在O(n)时间内完成吗?
注意:本题相对书上原题稍作改动
示例 1:
输入:[3,0,1]
输出:2
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/missing-number-lcci
class Solution:
def missingNumber(self, nums: List[int]) -> int:
'''
#哈希表
n = len(nums)
dt = {}
for v in nums:
dt[v] = 1
for i in range(n+1):
if dt.get(i,0) == 0:
return i
'''
#数学题
n = len(nums)
ans = (1+n)*n // 2
for v in nums:
ans -= v
return ans