当前位置:首页 > 编程笔记 > 正文
已解决

Leetcode41缺失的第一个正数

来自网友在路上 192892提问 提问时间:2023-11-06 00:17:58阅读次数: 92

最佳答案 问答题库928位专家为你答疑解惑

思路:原地哈希表

长度为N的数组,没有出现过的正整数一定是1~N+1中的一个。

此时会思考能不能用一个哈希表来保存出现过的1~N+1的数,然后从 1 开始依次枚举正整数,并判断其是否在哈希表中

但是题目要求常数级别的空间,就不能使用N的哈希表了。

这里将原数组当做哈希表,使用标记的办法来标记出现过的正整数,最后遍历数组,第一个没出现的下标+1就是答案

怎么样进行标记呢?

  • 先遍历一遍数组,将非正整数置为N+1
  • 再遍历一遍数组,将1~N正整数对应的下标位置置为负数
  • 最后遍历一遍数组,第一个不是负数的位置i+1就是没出现过的最小的正整数

 

class Solution {public int firstMissingPositive(int[] nums) {int len = nums.length;for(int i = 0;i<len;i++){if(nums[i]<=0){nums[i] = len+1;}}for(int i = 0;i<len;i++){int num = Math.abs(nums[i]);if(num<=len&&num>0){nums[num-1] = -Math.abs(nums[num-1]);}}for(int i = 0;i<len;i++){if(nums[i]>=0){return i+1;}}return len+1;} 
}

查看全文

99%的人还看了

猜你感兴趣

版权申明

本文"Leetcode41缺失的第一个正数":http://eshow365.cn/6-33132-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!