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 以记录目前为止找到的最长连续序列的长度。
相关推荐
8Qi85 小时前
LeetCode 75:颜色分类(荷兰国旗问题)—— Java 题解 ✅
java·算法·leetcode·指针·排序
888CC++6 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
你疯了抱抱我7 小时前
【Mac】vscode 配置 GD32E230CXXX 开发环境
ide·vscode·macos·嵌入式
2023自学中7 小时前
imx6ull 开发板 推流ov5640数据,虚拟机用 ffplay 拉流播放
linux·音视频·嵌入式·开发板
pluviophile_s7 小时前
数据结构:第2讲:线性表
数据结构·笔记
(●—●)橘子……8 小时前
力扣第503场周赛练习理解
python·学习·算法·leetcode·职场和发展·周赛
不脱发的程序猿9 小时前
AI Coding时上下文不够用咋办?
单片机·嵌入式硬件·嵌入式
明志数科9 小时前
4D时序标注技术详解:让机器人理解连续动作的数据基础
java·算法·机器人
feng_you_ying_li9 小时前
C++复习二,继承与多态
c++