7. 解密前端算法题:如何找出最长连续序列?

AI 概述
问题描述 给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。 请你设计并实现时间复杂度为 O(n) 的算法解决此问题。 示例 1: 输入:nums = [100,4,200,1,3,2] 输出:4 解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。 示例 2: 输入:nums = [0,3,7,2,5,8,4,...

解密前端算法题

问题描述

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

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

示例 1:

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

示例 2:

输入:nums = [0,3,7,2,5,8,4,6,0,1]
输出:9

提示:

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

解题思路:

  • 先给数组排序
  • 再给数组去重
  • 遍历排序去重后的数组,判断当前遍历的后一位和当前位的差值是否是 1,是则当前连续序列值(nowLen)+1;否则用当前序列值(nowLen)和最长序列值(maxLen)比较,获取最长序列,并初始化当前序列值(nowLen)为 1。

代码如下:

/**
 * @param {number[]} nums
 * @return {number}
 */
var longestConsecutive = function(nums) {
  if (nums.length === 0) {
    return 0
  }
  // 先排序
  nums.sort((a,b) => {
    return a - b
  })
  // 再去重
  nums = Array.from(new Set(nums))
  // 最后判断统计
  let maxLen = 1 // 记录连续最长序列
  let nowLen = 1 // 记录当前连续序列
  for (let i = 0; i < nums.length - 1; i++) {
     if (nums[i + 1] - nums[i] === 1) {
         nowLen++ if (i === nums.length - 2) { // 处理遍历到最后一位的情况(有可能最后一次是最长的序列)
         maxLen = nowLen > maxLen ? nowLen : maxLen
      }
    } else { // 每次不连续的时候判断是否是最长,并初始化 nowLen
      maxLen = nowLen > maxLen ? nowLen : maxLen
      nowLen = 1
    }
  }
  return maxLen
};

以上关于7. 解密前端算法题:如何找出最长连续序列?的文章就介绍到这了,更多相关内容请搜索码云笔记以前的文章或继续浏览下面的相关文章,希望大家以后多多支持码云笔记。

「点点赞赏,手留余香」

2

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 admin@mybj123.com 进行投诉反馈,一经查实,立即处理!
重要:如软件存在付费、会员、充值等,均属软件开发者或所属公司行为,与本站无关,网友需自行判断
码云笔记 » 7. 解密前端算法题:如何找出最长连续序列?

发表回复