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

相关推荐
-To be number.wan10 小时前
B 树 vs B+ 树:为什么 MySQL 用 B+ 树,而不是 B 树?
数据结构
杨间10 小时前
《排序算法全解析:从基础到优化,一文吃透八大排序!》
c语言·数据结构·排序算法
Remember_99310 小时前
【LeetCode精选算法】滑动窗口专题二
java·开发语言·数据结构·算法·leetcode
Gorgous—l11 小时前
数据结构算法学习:LeetCode热题100-动态规划篇(下)(单词拆分、最长递增子序列、乘积最大子数组、分割等和子集、最长有效括号)
数据结构·学习·算法
Remember_99312 小时前
【LeetCode精选算法】滑动窗口专题一
java·数据结构·算法·leetcode·哈希算法
Lueeee.12 小时前
v4l2驱动开发
数据结构·驱动开发·b树
漫随流水13 小时前
leetcode回溯算法(77.组合)
数据结构·算法·leetcode·回溯算法
超级大福宝14 小时前
【力扣200. 岛屿数量】的一种错误解法(BFS)
数据结构·c++·算法·leetcode·广度优先
一分之二~17 小时前
回溯算法--解数独
开发语言·数据结构·c++·算法·leetcode
不如语冰17 小时前
AI大模型入门1.1-python基础-数据结构
数据结构·人工智能·pytorch·python·cnn