题目:
给你一个含 n 个整数的数组 nums ,其中 nums[i] 在区间 [1, n] 内。请你找出所有在 [1, n] 范围内但没有出现在 nums 中的数字,并以数组的形式返回结果。
示例:
输入:nums = [4,3,2,7,8,2,3,1]
输出:[5,6]
思路:
方法1,哈希表
先把列表中的元素放到一个集合里,去掉了重复元素,然后从1到数组长度遍历,如果不在集合中,就加进结果里,返回结果,但是占用额外空间了。
方法2,原地修改数组,找到消失的数字,不占用额外的空间。
遍历数组中的数,让这个数减1作为索引,这样就能使索引遍历到数组中全部的位置了,让这个索引位置的数加n,就是数组长度,搞完一遍后就去遍历数组,如果哪个位置上的数小于或者等于n,说明在第一遍遍历数的时候,没有遍历到过这个位置加1的数,这个位置加1的数就是消失的数。放进结果数组中。
class Solution(object):
def findDisappearedNumbers(self, nums):
"""
:type nums: List[int]
:rtype: List[int]
"""
# set1 = set(nums)#集合,就是字典没有值,去掉重复元素,排序
# ans = []
# for i in range(1,len(nums)+1):
# if i not in set1:
# ans.append(i)
# return ans
# 占额外空间了
# 原地修改,找到不存在的元素
n = len(nums)
ans = []
for num in nums:
nums[num%n - 1] += n
for i in range(n):
if nums[i] <= n:
ans.append(i+1)
return ans