(leetcode学习)41. 缺失的第一个正数

avatar
作者
筋斗云
阅读量:0

给你一个未排序的整数数组 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

不管怎么说还是按照要求实现了,不看官方解法想不到

又学到一种方法,用正负数模拟哈希表

class Solution { public:     int firstMissingPositive(vector<int>& nums) {         int res, n = nums.size();         for(int i=0; i<n; i++){             if(nums[i] <= 0) nums[i] = n + 1;         }         for(int i=0; i<n; i++){             int cur = abs(nums[i]);             if( cur <= n ){                 nums[cur - 1] = -abs( nums[cur - 1] );             }         }         for(res=0; res<n; res++){             if(nums[res] > 0 ){                 break;             }         }         return res + 1;     } };

    广告一刻

    为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!