LeetCode 力扣 热题 100道(十九)最长连续序列(C++)

给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。

请你设计并实现时间复杂度为 O(n)的算法解决此问题。

cpp 复制代码
class Solution {
public:
    int longestConsecutive(vector<int>& nums) {
        unordered_set<int> numSet(nums.begin(), nums.end()); 
        int longestStreak = 0;
        for (int num : numSet) {
            if (numSet.find(num - 1) == numSet.end()) {
                int currentNum = num;
                int currentStreak = 1;
                while (numSet.find(currentNum + 1) != numSet.end()) {
                    currentNum++;
                    currentStreak++;
                }
                longestStreak = max(longestStreak, currentStreak);
            }
        }
        
        return longestStreak;
    }
};
  • 去重 :首先将输入的数组 nums 转换为哈希集合 numSet,这样就去除了重复的元素,并且能够在常数时间内检查元素是否存在。
  • 查找最长连续序列
    • 对于每一个数字 num,我们检查 num - 1 是否存在于集合中。如果不存在,说明 num 是某个连续序列的起始元素。
    • 然后从 num 开始,逐个检查 num + 1, num + 2, ... 是否存在于集合中,直到遇到不存在的元素。
  • 更新最长序列长度 :在每次查找完一个序列后,更新 longestStreak 以记录目前为止找到的最长连续序列的长度。
相关推荐
wearegogog12311 分钟前
基于遗传算法的阵列天线方向图优化MATLAB实现
算法·matlab
挨踢ren14 分钟前
C++ std::function:万能函数包装器
c++
Controller-Inversion20 分钟前
312. 戳气球
算法
图码21 分钟前
最大子数组和问题:从暴力到Kadane算法的优雅蜕变
数据结构·算法·动态规划·柔性数组
Raink老师24 分钟前
用100道题拿下你的算法面试(链表篇-5):删除链表的倒数第 N 个节点
算法·链表·面试
庞轩px25 分钟前
第一篇:Redis数据结构底层——String、List、Hash、Set、ZSet各自用什么实现的?
数据结构·redis·list·set·hash·string·zset
qq_2965532727 分钟前
[特殊字符] 数组中的递增三元组:O(n) 时间高效查找,面试必考!
数据结构·算法·面试·职场和发展·组合模式·柔性数组
今儿敲了吗33 分钟前
链表篇(一)——合并两个有序链表
数据结构·笔记·算法·链表
fie888933 分钟前
基于BBO算法的网络负载均衡优化(MATLAB实现)
网络·算法·负载均衡
初願致夕霞33 分钟前
Linux编程_应用层_HTTP与HTTPS协议
linux·c++·http·https