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;
    }
};
相关推荐
.普通人3 分钟前
算法基础(以acwing讲述顺序为主,结合自己理解,持续更新中...)
c++·算法
brzhang8 分钟前
为什么 A2A 和 MCP 缺一不可?
前端·后端·算法
strive-debug16 分钟前
上篇:《排序算法的奇妙世界:如何让数据井然有序?》
数据结构·算法·排序算法
徒步青云21 分钟前
七大排序算法及其优化
算法·排序算法
蔡蓝39 分钟前
jwt的无感刷新
算法·哈希算法
HelloDam1 小时前
912. 排序数组 超级通俗易懂、全面的快速排序教程(优化重复元素、实例有序问题)
后端·算法·排序算法
HelloDam2 小时前
leetcode51.N 皇后 回溯算法求解 + 效率优化
后端·算法
DataFunTalk2 小时前
30位数据科学家集结完毕,揭晓大模型时代数据科学的“晋级之路”
前端·后端·算法
ん贤2 小时前
图论基础理论
c语言·数据结构·c++·算法·图论