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