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;
    }
};
相关推荐
若云止水2 小时前
ngx_conf_handler - root html
服务器·前端·算法
lwewan4 小时前
26考研——查找_树形查找_二叉排序树(BST)(7)
数据结构·笔记·考研·算法
独好紫罗兰4 小时前
洛谷题单1-B2002 Hello,World!-python-流程图重构
python·算法·流程图
刚入门的大一新生5 小时前
数据结构初阶-二叉树链式
数据结构·算法
雨出5 小时前
算法学习第十六天:动态规划(补充题目)
学习·算法·动态规划
flying_13145 小时前
面试常问系列(一)-神经网络参数初始化
神经网络·算法·激活函数·正态分布·参数初始化·xavier·kaiming
uhakadotcom6 小时前
当待处理的日志到了TB级别,这些工具你不得不学起来...
算法·架构·github
এ旧栎6 小时前
蓝桥与力扣刷题(蓝桥 蓝桥骑士)
java·数据结构·算法·leetcode·蓝桥杯·二分·学习和成长
uhakadotcom6 小时前
使用airflow的10个具体实用案例
算法·面试·架构
编程绿豆侠7 小时前
力扣HOT100之子串:76. 最小覆盖子串
算法·leetcode