
铁子们好啊!阿辉来讲道题,这道题据说是23年字节3面真题,LeetCode上面hard难度,而且是很多难题的基础模板,今天阿辉就带你拿下它!!!
链接🔗:缺失的第一个正数
给你一个未排序的整数数组 nums ,请你找出其中没有出现的最小的正整数。
请你实现时间复杂度为 O(n) 并且只使用常数级别额外空间的解决方案。
示例 1:
输入:nums = [1,2,0]
输出:3
示例 2:
输入:nums = [3,4,-1,1]
输出:2
示例 3:
输入:nums = [7,8,9,11,12]
输出:1
首先这道题要求时间复杂度在O(n),空间复杂度在O(1)
很明显可以想到二分或者有限次的遍历数组

首先,我们准备两个数组偏移量left = 0和right = n(n代表数组的长度),left的位置表示待排序的位置,right首先是垃圾区的边界,其次right还表示能够排完整个连续不间断正整数数列的长度,所以一开始,right为n
class Solution {
public:
    int firstMissingPositive(vector& nums) {
        int left = 0;//左边界
        int right = nums.size();//右边界
        while (left < right) {//当left来到right时跳出循环
            if (nums[left] == left + 1) {//当left当前位置的数字为left+1时,++left
                ++left;
            }
            //垃圾区
            else if (nums[left] <= left || nums[left] > right || nums[left] == nums[nums[left] - 1]) {
                swap(nums[left], nums[--right]);
            }
            //当`left`当前位置的数字处于`left+1`到`right`之间
            //且它本该在的位置也空出来的时候时
            else {
                swap(nums[left], nums[nums[left] - 1]);
            }
        }
        return left + 1;//要加1,因为1在0位置,n就在n-1位置
    }
};
  
复杂度
时间复杂度:
O ( n ) O(n) O(n)
空间复杂度:
: O ( 1 ) O(1) O(1)
