【每天学习一点算法 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)

相关推荐
库奇噜啦呼1 小时前
【iOS】源码学习-类与对象底层原理
学习·ios·cocoa
一只数据集1 小时前
柏林道路路面图像数据集-971张沥青与鹅卵石路面图片-训练测试集划分-支持道路材质识别与自动驾驶视觉算法训练
算法·自动驾驶·材质
我不是懒洋洋1 小时前
【数据结构】二叉树OJ(单值二叉树、检查两棵树是否相同、对称二叉树、二叉树的前序遍历、另一颗树的子树)
c语言·数据结构·c++·经验分享·算法·leetcode·visual studio
wljy12 小时前
每日一题(2026.4.29) 猫猫与数学
c语言·c++·算法·蓝桥杯·stl·牛客
sali-tec2 小时前
C# 基于OpenCv的视觉工作流-章56-OCR
图像处理·人工智能·opencv·算法·计算机视觉·ocr
MicroTech20252 小时前
微算法科技(NASDAQ:MLGO)混合经典量子算法:赋能数字图像处理的创新路径
科技·算法·量子计算
yu85939582 小时前
降低OFDM系统PAPR的各种算法及误码率分析
前端·算法
不灭锦鲤2 小时前
网络安全学习第98天
学习·安全
阿Y加油吧2 小时前
二刷 LeetCode:5. 最长回文子串 & 1143. 最长公共子序列 复盘笔记
笔记·算法·leetcode