LC448(HOT100).找到所有数组中消失的数字(原地交换-简单)

该篇博客介绍了如何解决一个算法问题,即在给定的[1,n]范围内找到所有未在数组中出现的数字。博主提出了一个使用原地交换的策略,通过遍历数组并将值为正的元素置为负来标记已出现的数字,然后再次遍历找出未被标记的正数。这种方法的时间复杂度为O(n),空间复杂度为O(1)。博客强调了正确理解时间复杂度的重要性,即使遍历两次也仍然可以视为线性时间复杂度。
摘要由CSDN通过智能技术生成

   LC448:找到所有数组中消失的数字

题目:给你一个含 n 个整数的数组 nums ,其中 nums[i] 在区间 [1, n] 内。请你找出所有在 [1, n] 范围内但没有出现在 nums 中的数字,并以数组的形式返回结果。
思路:原地交换
复杂度:时间复杂度O(n)  空间复杂度O(1)
ps:时间复杂度为O(2n)也是O(n)的时间复杂度,不要总是觉得遍历两边复杂度就高了

'''
    题目:给你一个含 n 个整数的数组 nums ,其中 nums[i] 在区间 [1, n] 内。请你找出所有在 [1, n] 范围内但没有出现在 nums 中的数字,并以数组的形式返回结果。
    思路:从前向后遍历   将当前值-1对应的index位置 置为负数  因为可能会出现两次,所以当其为正时候置为负数  出现第二次忽略即可。
    复杂度:时间复杂度O(n)  空间复杂度O(1)
    ps:时间复杂度为O(2n)也是O(n)的时间复杂度,不要总是觉得遍历两边复杂度就高了
    例:  0 1 2 3 4 5 6 7     0  1  2  3  4  5  6  7
         4 3 2 7 8 2 3 1    -4 -3 -2 -7  8  2 -3 -1     返回  4+1  5+1
'''
def findDisappearedNumbers(nums):

    for i in range(len(nums)):
        if nums[abs(nums[i])-1] > 0:
            nums[abs(nums[i])-1] *= -1

    res = []
    for i in range(len(nums)):
        if nums[i] > 0:
           res.append(i+1)

    return res

 

路虽远,行则将至。事虽难,做则必成 。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值