LeetCode Hot100(3/100)——128.最长连续序列

文章目录

一、题目描述

给定一个 未排序的整数数组 nums ,要求找出其中的 最长连续元素序列的长度

连续序列 指的是数字可以按顺序排列,不要求原数组中相邻。

  • 例如:
    输入:nums = [100, 4, 200, 1, 3, 2]
    输出:4
    解释:最长连续序列是 [1, 2, 3, 4]

二、题目目标与挑战

  1. 不能排序后简单遍历 ------ 排序是 O(n log n),而本题要求能在平均 O(n) 时间解决。
  2. 要快速判断某个数字是否存在 ------ 用哈希结构(Set)是关键。

三、思路分析

解法一:HashSet + 边界扩展法(最优解)

核心思想:

  • 利用 HashSet 存储所有元素,保证查找存在性是 O(1)
  • 只从可能是连续序列"起点"的数字向右扩展,
    即:如果 num - 1 不在集合中,那么 num 就是一个连续序列的开头。
  • 扩展 num + 1num + 2...直到不连续为止。
算法流程图

num-1 不在集合中
num-1 在集合中
输入数组 nums
将所有元素插入 HashSet
初始化 maxLen = 0
遍历每个 num
从 num 向右扩展
计算当前连续长度 currLen
更新 maxLen = max(maxLen, currLen)
跳过,继续下一个 num
返回 maxLen

  • 核心举例:

nums = [100, 4, 200, 1, 3, 2] 为例:

数字 是否为序列起点 序列扩展结果 序列长度
100 ✅(100-1不在) [100] 1
4 ❌(3在) --- ---
200 ✅(199不在) [200] 1
1 ✅(0不在) [1,2,3,4] 4

最终得到最长连续序列长度 4


解法二:排序 + 遍历(容易想但性能一般)

步骤:

  1. 先排序。
  2. 从前向后统计连续数字段长度。

缺陷: 复杂度 O(n log n),无法满足高性能要求。

复杂度:

  • 时间:O(n log n)
  • 空间:O(1)(如果原地排序)

解法三:Union-Find 并查集(可做扩展)

思想是把相邻数字连成一组,最后找最大集合大小。

不过此题用 HashSet 扩展法更优,Union-Find 适合理解"元素连通关系"。


四、复杂度分析

方法 时间复杂度 空间复杂度
HashSet 扩展法 O(n) O(n)
排序遍历法 O(n log n) O(1)
Union-Find 法 O(n)(但常数高) O(n)

五、Java 最优解代码实现

java 复制代码
import java.util.HashSet;
import java.util.Set;

public class Solution {
    public int longestConsecutive(int[] nums) {
        Set<Integer> set = new HashSet<>();
        for (int num : nums) {
            set.add(num);
        }

        int longest = 0;
        for (int num : set) {
            // 只从序列起点开始扩展
            if (!set.contains(num - 1)) {
                int currentNum = num;
                int currentStreak = 1;

                while (set.contains(currentNum + 1)) {
                    currentNum++;
                    currentStreak++;
                }

                longest = Math.max(longest, currentStreak);
            }
        }
        return longest;
    }
}

总结

优点 缺点 适用场景
HashSet 扩展法速度快、思路直观 需额外 O(n) 空间 数组规模大、性能要求高
排序法实现简单 性能稍差 面试写得快但不是最优
并查集法结构更复杂 实现冗长 理解"连通"类型问题
相关推荐
小O的算法实验室20 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
郭涤生21 小时前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿21 小时前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz1 天前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能1 天前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****1 天前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能1 天前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能1 天前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo1 天前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
Proxy_ZZ01 天前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法