【面试经典150 | 哈希表】最长连续序列

文章目录

写在前面

本专栏专注于分析与讲解【面试经典150】算法,两到三天更新一篇文章,欢迎催更......
专栏内容以分析题目为主,并附带一些对于本题涉及到的数据结构等内容进行回顾与总结,文章结构大致如下,部分内容会有增删:

  • Tag:介绍本题牵涉到的知识点、数据结构;
  • 题目来源:贴上题目的链接,方便大家查找题目并完成练习;
  • 题目解读:复述题目(确保自己真的理解题目意思),并强调一些题目重点信息;
  • 解题思路:介绍一些解题思路,每种解题思路包括思路讲解、实现代码以及复杂度分析;
  • 知识回忆:针对今天介绍的题目中的重点内容、数据结构进行回顾总结。

Tag

【哈希表】【数组】


题目来源

128. 最长连续序列


题目解读

在无序数组中,找到最长的数字连续序列。要求时间复杂度为线性的。


解题思路

方法一:哈希表

要求的线性时间复杂度的解法,我们使用哈希集合来完成。

维护一个哈希集合,将数组中的所有元素加入到集合中;然后遍历集合中的数,统计这个数两头可以扩展到最大连续长度。

实现代码

cpp 复制代码
class Solution {
public:
	int longestConsecutive(vector<int>& nums) {
		unordered_set<int> hash;
		for (int num : nums)
			hash.insert(num);

		int ans = 0;
		while (!hash.empty()) {
			int cur = *(hash.begin());
			hash.erase(cur);

			int next = cur + 1, prev = cur - 1;
			while (hash.count(next))
				hash.erase(next++);
			while (hash.count(prev))
				hash.erase(prev--);
			ans = max(ans, next - prev - 1);
		}
		return ans;
	}
};

复杂度分析

时间复杂度: O ( n ) O(n) O(n), n n n 为数组 nums 的长度。

空间复杂度: O ( n ) O(n) O(n),哈希集合占用了额外的


写在最后

如果文章内容有任何错误或者您对文章有任何疑问,欢迎私信博主或者在评论区指出 💬💬💬。

如果大家有更优的时间、空间复杂度方法,欢迎评论区交流。

最后,感谢您的阅读,如果感到有所收获的话可以给博主点一个 👍 哦。

相关推荐
J ..几秒前
C++ Lambda 表达式完全指南
c++
跨境猫小妹8 分钟前
2025 TikTok Shop:从内容爆发到系统化深耕的商业跃迁
大数据·人工智能·算法·产品运营·亚马逊
不穿格子的程序员11 分钟前
从零开始写算法 —— 二叉树篇 1:二叉树的三种遍历(递归实现法)
算法·深度优先·二叉树遍历·fds
Qt程序员14 分钟前
从 C++11 到 C++23:枚举的原理升级与实践
c++·c++23
CC.GG16 分钟前
【C++】红黑树
java·开发语言·c++
子夜江寒27 分钟前
逻辑森林与贝叶斯算法简介
算法·机器学习
闻缺陷则喜何志丹35 分钟前
【计算几何 线性代数】仿射矩阵的秩及行列式
c++·线性代数·数学·矩阵·计算几何·行列式·仿射矩阵得秩
xu_yule1 小时前
算法基础-背包问题(01背包问题)
数据结构·c++·算法·01背包
特立独行的猫a1 小时前
C++ Core Guidelines(C++核心准则):2025现代C++开发关键要点总结
c++·core guidelines·核心准测
Joy-鬼魅1 小时前
VC中共享内存的命名空间
c++·vc·共享内存命名空间