无序数组中找出连续的数中第一个缺失的数字

发布于 2023-09-17 19:10:30 字数 618 浏览 76 评论 0

可以通过哈希表的方式来解决这个问题。

首先,遍历一遍数组,将数组中的数字都存入哈希表中。

然后,从数字 1 开始,遍历数字 1 到数组中的最大值,判断每个数字是否出现在哈希表中,如果某个数字不在哈希表中,那么它就是第一个缺失的数字。

代码如下:

def findFirstMissingNumber(nums):
    # 将数组中的数字存入哈希表中
    num_set = set(nums)

    # 从数字 1 开始,逐个判断数字是否在哈希表中
    missing_number = 1
    while missing_number in num_set:
        missing_number += 1

    # 返回第一个缺失的数字
    return missing_number

# 测试样例
nums = [1, 2, 4, 5]
print(findFirstMissingNumber(nums))  # 输出 3

这个算法的时间复杂度是 O(n),其中 n 是数组的长度。因为需要遍历一遍数组,并且需要遍历数字 1 到数组中的最大值。空间复杂度是 O(n),其中 n 是数组的长度,用于存储哈希表。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

撑一把青伞

暂无简介

文章
评论
29 人气
更多

推荐作者

櫻之舞

文章 0 评论 0

弥枳

文章 0 评论 0

m2429

文章 0 评论 0

野却迷人

文章 0 评论 0

我怀念的。

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文