128.最长连续序列
题目:给定一个未排序的整数数组,找出最长连续序列的长度。
要求算法的时间复杂度为 O(n)。
示例: 输入: [100, 4, 200, 1, 3, 2] 输出: 4
解释: 最长连续序列是 [1, 2, 3, 4]。它的长度为 4。
class Solution {
public:
int longestConsecutive(vector<int>& nums)
{
unordered_set<int> mp;//构建哈希表
for(int n : nums)
{
mp.insert(n);
}
int longestStreak = 0;
for(int num:mp)
{
//如果比当前元素小的值不存在,则可以进行查找和累加,避免了重复操作
if(!mp.count(num-1))
{
int currStreak = 1;
int currNum = num;
//比当前数字大1,则可以累加长度
while(mp.count(currNum + 1)) // 这一步要注意!!!!
{
currNum += 1;
currStreak += 1;
}
//求当前步骤和上一步的最大值
longestStreak = max(longestStreak, currStreak);
}
}
return longestStreak;
}
};
该博客介绍了一个在O(n)时间复杂度内解决寻找未排序整数数组中最长连续序列长度的问题。通过使用哈希表存储数组元素,遍历哈希表并检查每个元素的连续序列来实现。当找到一个没有前驱元素的数字时,开始计数并更新最长连续序列的长度。算法关键在于利用哈希表避免重复检查并有效地找到连续序列。

657

被折叠的 条评论
为什么被折叠?



