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) 空间 数组规模大、性能要求高
排序法实现简单 性能稍差 面试写得快但不是最优
并查集法结构更复杂 实现冗长 理解"连通"类型问题
相关推荐
weisian15123 分钟前
Java并发编程--47-分布式ID生成器:雪花算法(Snowflake)与时钟回拨问题
java·算法·时钟回拨·雪花算法id
itzixiao24 分钟前
L1-066 猫是液体(5分)[java][python]
java·开发语言·python·算法
ytttr87326 分钟前
MATLAB SIFT图像配准实现
算法·机器学习·matlab
小饕29 分钟前
从 Word2Vec 到多模态:词嵌入技术的演进全景
人工智能·算法·机器学习
海参崴-30 分钟前
AVL树完整实现与深度解析
算法
一个爱编程的人38 分钟前
一个数是不是素数
数据结构·算法
Hui_AI72042 分钟前
基于RAG的农产品GEO溯源智能问答系统实现
开发语言·网络·人工智能·python·算法·创业创新
lwf00616443 分钟前
FFM (Field-aware Factorization Machine) 学习日记
算法·机器学习
南宫萧幕43 分钟前
HEV能量管理控制算法实战:从MPC/RL理论基础到Simulink闭环建模
算法·matlab·汽车·控制·pid
IT猿手1 小时前
SCI一区:章鱼优化算法(Octopus Optimization Algorithm, OOA)求解23个测试函数,出图丰富,提供完整MATLAB代码
开发语言·算法·matlab