leetcode448.找到所有数组中消失的数字

题目:

给你一个含 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 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值