📑 题目:41. 缺失的第一个正数

🚀 本题 LeetCode 传送门

题目大意

找到缺失的第一个正整数。

解题思路

为了减少时间复杂度,可以把 input 数组都装到 map 中,然后 i 循环从 1 开始,依次比对 map 中是否存在 i,只要不存在 i 就立即返回结果,即所求。

代码

  1. package leetcode
  2. func firstMissingPositive(nums []int) int {
  3. numMap := make(map[int]int, len(nums))
  4. for _, v := range nums {
  5. numMap[v] = v
  6. }
  7. for index := 1; index < len(nums)+1; index++ {
  8. if _, ok := numMap[index]; !ok {
  9. return index
  10. }
  11. }
  12. return len(nums) + 1
  13. }