【每天学习一点算法 2026/04/29】最长连续序列

每天学习一点算法 2026/04/29

题目:最长连续序列

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

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

我们首先分析一下,如果要找到递增序列,是不是得找到开头,然后再计算有多个递增元素即可,那么我们怎么找到递增序列的开头呢?我们只需要找到一个元素 n 同时数组中没有 n - 1 这个元素,这就是表示这个 n 是可能的递增序列开头,这里我们直接使用 set 可以快速的找到递增序列开头。

typescript 复制代码
function longestConsecutive(nums: number[]): number {
  if (nums.length < 2) return nums.length // 数组长度为 0 和 1 时,最长序列长度就是 0 和 1
  const set = new Set(nums) // 根据nums创建set
  let max = 1 // 记录最长序列长度
  set.forEach(value => {
    // 循环找到递增序列开头
    if (!set.has(value - 1)) {
      let len = 1
      // 计算当前序列长度
      while (set.has(++value)) len++
      // 记录最长序列长度
      max = Math.max(max, len)
    }
  })

  return max
};

题目来源:力扣(LeetCode)

相关推荐
辰海Coding5 小时前
MiniSpring框架学习笔记-解决循环依赖的简化IoC容器
笔记·学习
晓梦林5 小时前
cp520靶场学习笔记
android·笔记·学习
心中有国也有家6 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
Upsy-Daisy6 小时前
AI Agent 项目学习笔记(八):Tool Calling 工具调用机制总览
人工智能·笔记·学习
绝知此事6 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
碧海银沙音频科技研究院6 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
csdn_aspnet7 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
LuminousCPP8 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习
魔法阵维护师8 小时前
从零开发游戏需要学习的c#模块,第十四章(保存和加载)
学习·游戏·c#