给你一个未排序的整数数组 nums
,请你找出其中没有出现的最小的正整数。
请你实现时间复杂度为 O(n)
并且只使用常数级别额外空间的解决方案。
示例 1:
输入:nums = [1,2,0] 输出:3
示例 2:
输入:nums = [3,4,-1,1] 输出:2
示例 3:
输入:nums = [7,8,9,11,12] 输出:1
提示:
1 <= nums.length <= 5 * 105
-231 <= nums[i] <= 231 - 1
int firstMissingPositive(vector<int>& nums) {
vector<int> vec(500000,0);
for(int i=0;i<nums.size();i++)
{
if(nums[i]<=0 || nums[i] >=500000)
{
continue;
}
vec[nums[i]]=1;
}
for(int i=1;i<vec.size();i++)
{
if(vec[i]==0)
{
return i;
}
}
return 1;
}