[LeetCode] 最长连续序列

Instruction

**难度: **中等; **分类: **哈希

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

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

示例 1:

ini 复制代码
输入: nums = [100,4,200,1,3,2]
输出: 4
解释: 最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。

示例 2:

ini 复制代码
输入: nums = [0,3,7,2,5,8,4,6,0,1]
输出: 9

示例 3:

ini 复制代码
输入: nums = [1,0,1,2]
输出: 3

提示:

  • 0 <= nums.length <= 105
  • -109 <= nums[i] <= 109

思路

仍然给定一个哈希表,遍历里面每一个元素x,判断哈希表内是否有x - 1的元素, 若不存在,那么以x作为起点的x + 1, x + 2... x + y的最长连续序列即为x, x + 1, x + 2 ... x + y,长度为 y + 1

题解

js 复制代码
/**
 * @param {number[]} nums
 * @return {number}
 */
var longestConsecutive = function(nums) {
   const numSet = new Set(nums);
   let longestStreak = 0;

   for(const num of numSet) {
    if(!numSet.has(num - 1)) {
        let currentNum = num;
        let currentStreak = 1;

        while(numSet.has(currentNum + 1)) {
            currentNum += 1;
            currentStreak += 1;
        }

        longestStreak = Math.max(longestStreak, currentStreak)
    }
   }

   return longestStreak;
};
相关推荐
pe7er19 小时前
window管理开发环境篇 - 持续更新
前端·后端
We་ct20 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
陈随易1 天前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·后端·程序员
王老师青少年编程1 天前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
冰暮流星1 天前
javascript之事件代理/事件委托
前端
叼烟扛炮1 天前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说1 天前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
陈随易1 天前
AI时代,你还在坚持手搓文章吗
前端·后端·程序员
wuweijianlove1 天前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung1 天前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展