给你一个未排序的整数数组
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
cppclass Solution { public: int firstMissingPositive(vector<int>& nums) { int n=nums.size(); for(int i=0;i<n;i++) { while(nums[i]>=1&&nums[i]<=n&&nums[i]!=nums[nums[i]-1]) { swap(nums[i],nums[nums[i]-1]); } } for(int i=0;i<n;i++) { if(nums[i]!=i+1) { return i+1; } } return n+1; } };
LeetCode 41. 缺失的第一个正数
Liangwei Lin2026-05-09 14:22
相关推荐
JieE21224 分钟前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题Jack208 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理小小杨树10 小时前
读懂色彩:拍照调色不再难JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解vivo互联网技术1 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像Darling噜啦啦1 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点用户497863050731 天前
(一)小红的数组操作怕浪猫2 天前
Electron 系列文章封面图