41. First Missing Positive
Hard42.5% acceptance1,698,854 / 4,001,294 submissions
Asked by 35 companies
Topics
Given an unsorted integer array nums. Return the smallest positive integer that is not present in nums.
You must implement an algorithm that runs in O(n) time and uses O(1) auxiliary space.
Example 1:
Input: nums = [1,2,0] Output: 3 Explanation: The numbers in the range [1,2] are all in the array.
Example 2:
Input: nums = [3,4,-1,1] Output: 2 Explanation: 1 is in the array but 2 is missing.
Example 3:
Input: nums = [7,8,9,11,12] Output: 1 Explanation: The smallest positive integer 1 is missing.
Constraints:
1 <= nums.length <= 105-231 <= nums[i] <= 231 - 1
Hints
Hint 1
Think about how you would solve the problem in non-constant space. Can you apply that logic to the existing space?
Hint 2
We don't care about duplicates or non-positive integers
Hint 3
Remember that O(2n) = O(n)
Similar Questions
Missing NumberEasyFind the Duplicate NumberMediumFind All Numbers Disappeared in an ArrayEasyCouples Holding HandsHardSmallest Number in Infinite SetMediumMaximum Number of Integers to Choose From a Range IMediumSmallest Missing Non-negative Integer After OperationsMediumMaximum Number of Integers to Choose From a Range IIMediumSmallest Missing Integer Greater Than Sequential Prefix SumEasy