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

相关推荐
H__Rick3 分钟前
C51学习-DAY8
单片机·嵌入式硬件·学习
装不满的克莱因瓶33 分钟前
掌握生成对抗网络(GAN)的优化目标与评估指标——从博弈函数到生成质量衡量体系
人工智能·python·深度学习·算法·机器学习
技术小黑36 分钟前
CNN算法实战系列06 | InceptionV1实现猴痘病识别
深度学习·算法·cnn·inceptionv1
chase。1 小时前
【学习笔记】Dexora:面向高自由度双臂灵巧操作的开源 VLA 系统
笔记·学习
風清掦1 小时前
【STM32学习笔记-15】FLASH 闪存(Claude)
笔记·stm32·单片机·嵌入式硬件·学习
新时代牛马1 小时前
内核调试方法
linux·学习
云淡风轻~窗明几净1 小时前
角谷猜想的任意算法测试
数据结构·人工智能·算法
我想我不够好。1 小时前
贝利亚 扎克
学习
happygrilclh1 小时前
赚外快了:等离子表面处理机电源算法需求说明
算法
ji198594431 小时前
MATLAB 求散点曲线斜率
开发语言·算法·matlab