news 2026/6/9 23:41:23

41. 缺失的第一个正数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
41. 缺失的第一个正数

41. 缺失的第一个正数

困难

给你一个未排序的整数数组nums,请你找出其中没有出现的最小的正整数。

请你实现时间复杂度为O(n)并且只使用常数级别额外空间的解决方案。

示例 1:

输入:nums = [1,2,0] 输出:3 解释:范围 [1,2] 中的数字都在数组中。

示例 2:

输入:nums = [3,4,-1,1] 输出:2 解释:1 在数组中,但 2 没有。

示例 3:

输入:nums = [7,8,9,11,12] 输出:1 解释:最小的正数 1 没有出现。

提示:

  • 1 <= nums.length <= 105
  • -231 <= nums[i] <= 231 - 1

📝 核心笔记:缺失的第一个正数 (原地哈希)

1. 核心思想 (一句话总结)

“一个萝卜一个坑”。

利用数组下标作为哈希表的 Key。我们要把数值 x 强行交换到下标 x-1 的位置上(例如:数值 1 放下标 0,数值 3 放下标 2)。

💡 直观理解:

想象你在整理杂乱的带有编号的球(1号球、5号球...)。

规则是:拿到 k号球,就把它扔到 第 k-1 个 盒子里。

最后从头检查盒子,第一个“球号不对应”的盒子,就是缺少的那个球。

2. 算法流程 (归位 -> 查岗)
  1. 归位 (Swapping):遍历数组,只要当前数字nums[i]是个“正经数”(在1n之间),并且它没在正确的位置上,就把它交换到正确的位置去。
    • 注意:交换回来的新数字可能还需要继续交换,所以用while
  1. 查岗 (Checking):再次遍历数组,看哪个下标i里的数字不是i+1
  2. 兜底:如果全都对上了,说明缺的是n+1

🔍 代码回忆清单 (关键点注释)

// 题目:LC 41. 缺失的第一个正数 class Solution { public int firstMissingPositive(int[] nums) { int n = nums.length; for (int i = 0; i < n; i++) { // 关键点1:While循环 (不是 if) // 只要拿到的数字符合要求,且没归位,就一直换,直到换无可换 while (nums[i] >= 1 && nums[i] <= n && nums[i] != nums[nums[i] - 1]) { // 防死循环:如果目标位置已经是正确的数字,就别换了 // 关键点2:交换逻辑 (把 x 放到 x-1 处) swap(nums, i, nums[i] - 1); } } // 关键点3:寻找第一个不匹配的 for (int i = 0; i < n; i++) { if (nums[i] != i + 1) { return i + 1; // 找到了!缺的就是 i+1 } } return n + 1; // 既然 1~n 都在,那缺的就是 n+1 } private void swap(int[] nums, int i, int j) { int temp = nums[i]; nums[i] = nums[j]; nums[j] = temp; } }

⚡ 快速复习 CheckList (易错点)

  • [ ]为什么用while
    • 这是最容易错的地方。交换过来的新数字nums[i]可能还是错的(例如把5换走了,换回来个3),3也得去它该去的地方,所以要一直换,直到当前位置无法再处理为止。
  • [ ]循环终止条件?
    1. 数字越界 (<=0>n):没地方放,不管它。
    2. 目标位置已经对了 (nums[i] == nums[target]):避免死循环(比如两个位置都是5,无限互换)。
  • [ ]时间复杂度?
    • 虽然是双重循环,但每个数字最多被交换一次归位。整体是 O(N)。

🖼️ 场景模拟

数组:[3, 4, -1, 1]

  • i=0 (Val=3):3 应该去下标 2。交换!->[-1, 4, 3, 1]
  • i=0 (Val=-1):-1 没地方去,跳过。
  • i=1 (Val=4):4 应该去下标 3。交换!->[-1, 1, 3, 4]
  • i=1 (Val=1):1 应该去下标 0。交换!->[1, -1, 3, 4]
  • i=1 (Val=-1):-1 跳过。
  • ...
  • 最后检查:下标 1 的值是 -1 (应该是 2)。返回 2
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 22:26:33

还买啥USB网卡~直接开启RNDIS就行

本文以Air780EPM系列核心板/开发板为例&#xff0c;分享在Windows及Linux系统下&#xff0c;通过RNDIS方式实现USB上网的要点。一、Windows下使用RNDIS功能Windows系统默认支持RNDIS&#xff0c;直接用USB连接板子和电脑就可以使用。1.1 核心示例代码open_rndis.lua核心代码如下…

作者头像 李华
网站建设 2026/6/6 22:22:25

Nginx详讲

目录一、Nginx简介1、Nginx是什么2、Nginx的优势3、Nginx下载二、Nginx的核心功能1、Nginx的反向代理什么是反向代理&#xff1f;简单的反向代理完整的基础配置反向代理解释2、Nginx的负载均衡。。什么是负载均衡&#xff1f;负载均衡算法&#xff08;核心&#xff09;3、Nginx…

作者头像 李华
网站建设 2026/6/9 18:41:28

【linux】——看一个动态库的所有函数

1. 命令 nm -D --defined-only rkllm-runtime/Linux/librkllm_api/aarch64/librkllmrt.so | grep -E " [Tt] " 打印信息 00000000000d0be4 T rkllm_abort 00000000000d1390 T rkllm_accuracy_analysis 00000000000d0c04 T rkllm_clear_kv_cache 00000000000d0c54 T r…

作者头像 李华
网站建设 2026/6/7 2:26:28

AI与区块链共舞:智能量化跟单软件开启策略优化与风险控制新纪元

引言在数字货币市场日均交易量突破2000亿美元的当下&#xff0c;传统交易方式正面临前所未有的挑战。当比特币价格在24小时内经历30%的剧烈波动时&#xff0c;人类交易员的生理极限与情绪干扰成为盈利的桎梏。而智能量化跟单软件的崛起&#xff0c;正以AI算法的冷峻理性重构投资…

作者头像 李华
网站建设 2026/6/9 3:54:19

Web3钱包2.0时代:AI、量子抗性与跨链宇宙,2025年开发者必知的三大革命

引言&#xff1a;Web3钱包——数字世界的“瑞士银行”在2025年的区块链浪潮中&#xff0c;Web3钱包已从边缘工具演变为数字经济的核心基础设施。它不仅是用户存储加密资产的“保险柜”&#xff0c;更是连接DeFi、NFT、DAO等去中心化应用的“万能钥匙”。据CoinGecko数据显示&am…

作者头像 李华