128. 最长连续序列

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

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

示例 1:

复制代码
输入:nums = [100,4,200,1,3,2]
输出:4
解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。

示例 2:

复制代码
输入:nums = [0,3,7,2,5,8,4,6,0,1]
输出:9

提示:

  • 0 <= nums.length <= 105
  • -109 <= nums[i] <= 109
cpp 复制代码
class Solution {
public:
    int longestConsecutive(vector<int>& nums) {
        int n = nums.size();
        if(n==0)
            return 0;
        if(n==1)
            return 1;
        sort(nums.begin(),nums.end());
        int l=0;
        int r=l+1;
        int mx=0;
        int eql=0;
        while(r<n)
        {
            if( nums[r-1]+1==nums[r])
            {
            }
            else if(nums[r-1]==nums[r])
            {
                eql+=1;
            }
            else
            {
                mx=max(r-l-eql,mx);
                eql=0;
                l=r;
            }
            r++;
        }
        return max(r-l-eql,mx);
    }
};
相关推荐
JohnFF7 分钟前
48. 旋转图像
数据结构·算法·leetcode
bbc1212267 分钟前
AT_abc306_b [ABC306B] Base 2
算法
生锈的键盘15 分钟前
推荐算法实践:movielens数据集
算法
董董灿是个攻城狮16 分钟前
Transformer 通关秘籍9:词向量的数值实际上是特征
算法
代码AC不AC24 分钟前
【数据结构】队列
c语言·数据结构·学习·队列·深度讲解
林泽毅24 分钟前
SwanLab x EasyR1:多模态LLM强化学习后训练组合拳,让模型进化更高效
算法·llm·强化学习
小林熬夜学编程26 分钟前
【高并发内存池】第八弹---脱离new的定长内存池与多线程malloc测试
c语言·开发语言·数据结构·c++·算法·哈希算法
刚入门的大一新生33 分钟前
归并排序延伸-非递归版本
算法·排序算法
独好紫罗兰38 分钟前
洛谷题单3-P1980 [NOIP 2013 普及组] 计数问题-python-流程图重构
开发语言·python·算法
独好紫罗兰42 分钟前
洛谷题单3-P1009 [NOIP 1998 普及组] 阶乘之和-python-流程图重构
开发语言·python·算法