LeetCode 41题:缺失的第一个正数

目录

题目

思路

代码


题目

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

思路

想要实现题目要求的时空限制,可以利用哈希表。

根据题目分析,我们只需要考虑在 [ 1,numsize ]范围内的数据,如果数据都不在该范围内,则应该返回 1。构建哈希表的哈希方法是:该范围内数的地址 = 数值减一,然后将该地址标记,标记方法为取负,在此之前,需要将所有小于等于0的数换为 numsize+1。

标记之后遍历数组,出现的第一个正数的下标加1便是结果。

代码

cs 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <math.h>

int firstMissingPositive(int *nums, int numsSize);

int main()
{
    int size = 2;
    int nums[4] = {2, 1};
    int res = firstMissingPositive(nums, size);
    printf("%d", res);
    return 0;
}

int firstMissingPositive(int *nums, int numsSize)
{
    for (int i = 0; i < numsSize; i++)
    {
        if (nums[i] <= 0)
        {
            nums[i] = numsSize + 1;
        }
    }
    for (int i = 0; i < numsSize; i++)
    {
        int t = fabs(nums[i]);
        if (t < numsSize + 1 && nums[t - 1] > 0)
        {
            nums[t - 1] = -nums[t - 1];
        }
    }
    int i;
    for (i = 0; i < numsSize; i++)
    {
        if (nums[i] >= 0)
        {
            break;
        }
    }
    return i + 1;
}
相关推荐
老虎062714 分钟前
LeetCode热题100 刷题笔记(第四天)二分 「 寻找两个正序数组的中位数」
笔记·算法·leetcode
_日拱一卒16 分钟前
LeetCode:最小覆盖字串
java·数据结构·算法·leetcode·职场和发展
小O的算法实验室16 分钟前
2026年IEEE TEVC,面向农业多机器人任务分配的自适应多目标任务划分算法,深度解析+性能实测
算法·机器人·论文复现·智能算法·智能算法改进
Ujimatsu19 分钟前
数据分析相关面试题-A/B 测试 & 统计学部分
算法·机器学习·数据分析
郝学胜-神的一滴21 分钟前
Qt6 + OpenGL 3.3 渲染环境搭建全指南:从空白窗口到专属渲染画布的优雅实现
数据结构·c++·线性代数·算法·系统架构·图形渲染
Omics Pro23 分钟前
空间组学下一代机器学习与深度学习
大数据·人工智能·深度学习·算法·机器学习·语言模型·自然语言处理
小肥米38 分钟前
分块查找ASL公式推导,为什么是两个ASL之和
数据结构·算法
样例过了就是过了40 分钟前
LeetCode热题100 最小栈
数据结构·c++·算法·leetcode
计算机安禾43 分钟前
【数据结构与算法】第18篇:数组的压缩存储:对称矩阵、三角矩阵与稀疏矩阵
c语言·开发语言·数据结构·c++·线性代数·算法·矩阵
今儿敲了吗44 分钟前
51| 八皇后
c++·笔记·学习·算法·深度优先