leetcode128.最长连续序列

可以用哈希表解决,先遍历选取每一个元素num作为起始值,然后判断num+1是否也在数组中,如果在就序列长度+1,但是用哈希表这么做实际上时间复杂度为o(n^2),为了降低到n,每一个元素只能访问一次,那么也就是如果num做为起始值,那么他的前驱num-1是不能在数组中的,这样就可以避免重复访问

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

        int result=0;
        for(const int& num:nums){
            if(numSet.find(num-1)!=numSet.end())
                continue;
            else{
                int len=1;
                int currentNum=num;
                while(numSet.find(currentNum+1)!=numSet.end()){
                    len++;
                    currentNum++;
                }
                result=max(result,len);
            }
        }
        return result;
    }
};

然而虽然代码和官方差不多还是有用例超时,对于如下这种有m个0的如果作为起始值,后续还有1,2,3,4让其进入内层循环的,时间复杂度为o(mn),为了避免这种情况还得对0去重

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

        int result=0;
        unordered_set<int> remDup;
        for(const int& num:nums){
            if(numSet.find(num-1)!=numSet.end()||remDup.find(num)!=remDup.end())
                continue;
            else{
                remDup.insert(num);
                int len=1;
                int currentNum=num;
                while(numSet.find(currentNum+1)!=numSet.end()){
                    len++;
                    currentNum++;
                }
                result=max(result,len);
            }
        }
        return result;
    }
};
相关推荐
vyuvyucd19 小时前
Java数组与Arrays类实战指南
数据结构·算法
csuzhucong19 小时前
七彩鹦鹉螺魔方
算法
逝川长叹19 小时前
利用 SSI-COV 算法自动识别线状结构在环境振动下的模态参数研究(Matlab代码实现)
前端·算法·支持向量机·matlab
山上三树19 小时前
详细介绍 C 语言中的匿名结构体
c语言·开发语言·算法
EXtreme3519 小时前
【数据结构】彻底搞懂二叉树:四种遍历逻辑、经典OJ题与递归性能全解析
c语言·数据结构·算法·二叉树·递归
炽烈小老头19 小时前
【每天学习一点算法 2026/01/09】3的幂
学习·算法
渡我白衣19 小时前
计算机组成原理(14):算术逻辑单元ALU
大数据·人工智能·算法·机器学习·计组·数电·alu
柳鲲鹏19 小时前
OpenCV视频实时跟踪目标,多种算法,python版
opencv·算法·音视频
朱峥嵘(朱髯)19 小时前
数据库如何根据估计 NDV,以及通过分区 NDV 推导全局 NDV
数据库·算法
山上三树19 小时前
详细介绍 C 语言 typedef 及与 #define 的核心对比
c语言·数据结构·算法