【力扣】41. 缺失的第一个正数

41. 缺失的第一个正数

题目描述

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

解题方法

哈希数组

  • C 语言
c 复制代码
int firstMissingPositive(int* nums, int numsSize) {
    int tab[numsSize + 1];
    memset(tab, 0, sizeof(tab));

    for (int i = 0; i < numsSize; i++) {
        if (nums[i] > 0 && nums[i] <= numsSize) {
            tab[nums[i]] += 1;
        }
    }

    for (int i = 1; i < numsSize + 1; i++) {
        if (tab[i] == 0) {
            return i;
        }
    }

    return numsSize + 1;
}
相关推荐
YGGP几秒前
【Golang】LeetCode 70. 爬楼梯
算法·leetcode
小熳芋几秒前
组合总和- python-回溯哦&剪枝
算法·机器学习·剪枝
lxh01137 分钟前
缺失的第一个正数
数据结构·算法
啊阿狸不会拉杆7 分钟前
《数字图像处理》第 12 章 - 图像模式分类
图像处理·人工智能·算法·机器学习·计算机视觉·分类·数据挖掘
LYFlied13 分钟前
【每日算法】LeetCode 763. 划分字母区间(贪心算法)
前端·算法·leetcode·面试·贪心算法
zore_c14 分钟前
【数据结构】二叉树初阶——超详解!!!(包含二叉树的实现)
c语言·开发语言·数据结构·经验分享·笔记·算法·链表
尋有緣15 分钟前
力扣1225-报告系统状态的连续日期
数据库·sql·算法·leetcode·oracle
代码游侠20 分钟前
学习笔记——网络基础
linux·c语言·网络·笔记·学习·算法
热爱生活的五柒21 分钟前
深度聚类(Deep Clustering)与度量学习(Metric Learning)的共同点和不同点
人工智能·算法·机器学习
LYFlied10 小时前
【每日算法】LeetCode 153. 寻找旋转排序数组中的最小值
数据结构·算法·leetcode·面试·职场和发展