无序数组中找出连续的数中第一个缺失的数字
可以通过哈希表的方式来解决这个问题。
首先,遍历一遍数组,将数组中的数字都存入哈希表中。
然后,从数字 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 技术交流群。

上一篇: Python 旋转数组
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论