LeetCode热题100-最长连续序列

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

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

题目要求时间复杂度On,如果使用暴力解法时间复杂度为On2,不满足要求。解体的关键点在于避免重复遍历,只从连续序列的 "起点" 开始计数,这样才能保证每个数字只被处理一次,实现真正的 O (n) 效率。

判断「num-1 不存在」,就是筛选出 "序列起点":

  • 1 的 num-1 = 0(不在集合中)→ 是起点,开始计数;
  • 2 的 num-1 = 1(在集合中)→ 不是起点,跳过;
  • 3 的 num-1 = 2(在集合中)→ 不是起点,跳过;
  • 4 的 num-1 = 3(在集合中)→ 不是起点,跳过;
  • 100 的 num-1 = 99(不在集合中)→ 是起点,计数;
  • 200 的 num-1 = 199(不在集合中)→ 是起点,计数;这样每个序列只从起点遍历一次,所有数字总共只被处理一遍,时间复杂度就是 O (n)。
python 复制代码
class Solution:
    def longestConsecutive(self, nums: List[int]) -> int:
        nums_set = set(nums)  # 去重很关键

        max_len = 0

        for num in nums_set:
            if num -1 not in nums_set:
                cur_num = num
                cur_len = 1
                while cur_num + 1 in nums_set:
                    cur_num += 1
                    cur_len += 1
                
                max_len = max(cur_len, max_len)
        
        return max_len
相关推荐
这里没有酒4 小时前
[信息安全] AES128 加密/解密 --> state 矩阵
算法
无限进步_4 小时前
【C++】多重继承中的虚表布局分析:D类对象为何有两个虚表?
开发语言·c++·ide·windows·git·算法·visual studio
TImCheng06095 小时前
内容运营岗位适合考哪个AI证书,与算法认证侧重点分析
人工智能·算法·内容运营
赵域Phoenix5 小时前
混沌系统是什么?
人工智能·算法·机器学习
CoderCodingNo5 小时前
【GESP】C++五、六级练习题 luogu-P1886 【模板】单调队列 / 滑动窗口
开发语言·c++·算法
paeamecium5 小时前
【PAT甲级真题】- All Roads Lead to Rome (30)
数据结构·c++·算法·pat考试·pat
Cando学算法5 小时前
双指针之快慢指针
算法
汀、人工智能5 小时前
[特殊字符] 第100课:任务调度器
数据结构·算法·数据库架构·贪心··任务调度器
每日任务(希望进OD版)5 小时前
二分法刷题
算法·二分