Leecode hot100 - 448. 找到所有数组中消失的数字

题目描述

448. 找到所有数组中消失的数字 - 力扣(LeetCode)

给你一个含 n 个整数的数组 nums ,其中 nums[i] 在区间 [1, n] 内。请你找出所有在 [1, n] 范围内但没有出现在 nums 中的数字,并以数组的形式返回结果。

示例 1:

复制代码
输入:nums = [4,3,2,7,8,2,3,1]
输出:[5,6]

示例 2:

复制代码
输入:nums = [1,1]
输出:[2]

思路

将元素值和索引对应起来,因为索引是不缺的,但是值会缺

将遍历到的值对应的索引对应的数变成负数,最后值还为正的,说明没有值让这个索引对应的数变负,因此找到结果

代码

class Solution:

def findDisappearedNumbers(self, nums: List[int]) -> List[int]:

讲元素值和索引对应起来,因为索引是不缺的,但是值会缺

将遍历到的值对应的索引对应的数变成负数,最后值还为正的,说明没有值让这个索引对应的数变负,因此找到结果

for num in nums:

idx = abs(num) -1 # 值对应的索引,注意索引要减1

nums[idx] = -1 * abs(nums[idx])

return [ i+1 for i, num in enumerate(nums) if num > 0 ] # 注意变成值是i+1

相关推荐
LBJ辉1 小时前
第 4 章 串
数据结构·考研
似水এ᭄往昔2 小时前
【C++】--封装红⿊树实现mymap和myset
开发语言·数据结构·c++·算法·stl
山楂树の3 小时前
搜索插入位置(二分查找)
数据结构·算法
Ka1Yan4 小时前
[二叉树] - 代码随想录:二叉树的统一迭代遍历
数据结构·算法·leetcode
Sheep Shaun4 小时前
二叉搜索树(下篇):删除、优化与应用
数据结构·c++·b树·算法
鱼鱼块4 小时前
二叉搜索树:让数据在有序中生长的智慧之树
javascript·数据结构·面试
jianfeng_zhu5 小时前
二叉树的中序线索化,并通过线索化后遍历二叉树
数据结构·链表
C雨后彩虹5 小时前
5G网络建设
java·数据结构·算法·华为·面试
酸菜牛肉汤面5 小时前
5、索引的数据结构(b+树,hash)
数据结构·b树·哈希算法
爱学习的小仙女!7 小时前
顺序表定义、特点和基本操作(含C代码详细讲解)及时间复杂度
数据结构·算法