内容简介:给定一个未排序的整数数组,找出最长连续序列的长度。 要求算法的时间复杂度为输入:[100, 4, 200, 1, 3, 2]解释:最长连续序列是 [1, 2, 3, 4]。它的长度为 4。
给定一个未 排序 的整数数组,找出最长连续序列的长度。 要求算法的时间复杂度为 O(n) 。
示例:
输入:[100, 4, 200, 1, 3, 2]
输出: 4
解释:最长连续序列是 [1, 2, 3, 4]。它的长度为 4。
思路
- 连续序列,首先要对传入数组进行 排序
-
连续序列的标志为
s[n] - s[n-1] === 1,针对这个来进行循环判断 -
定义循环中的最大长度
num以及最终长度max,每次需取max(num, max) - 当 s[n] - s[n-1] !== 1 时,及连续序列断开,需重置当前最大长度
- 特殊用例情况:[1,2,2,3]中的连续序列为[1,2,3],长度为3。因此在循环中当s[n] === s[n-1]时候,应跳过
直接上代码
/**
* @param {number[]} nums
* @return {number}
*/
var longestConsecutive = function(nums) {
if (!nums.length) return 0;
var sortedNums = nums.sort((a,b) => (a - b));
var i = 1;
var num = 1;
var max = 1;
while(i < sortedNums.length) {
if (sortedNums[i] - sortedNums[i - 1] === 1) {
num++;
} else if (sortedNums[i] === sortedNums[i - 1]) {
i++;
continue;
} else {
num = 1;
}
max = Math.max(max, num);
i++;
}
return max
};
复制代码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
网站入侵与脚本攻防修炼
逍遥 / 2008-9 / 59.00元
《网站入侵与脚本攻防修炼》从“攻”、“防”两个角度,通过现实中的入侵实例,并结合原理性的分析,图文并茂地展现网站入侵与防御的全过程。全书共分8章,系统地介绍网站入侵的全部过程,以及相应的防御措施和方法。其中包括网站入侵的常见手法、流行网站脚本入侵手法揭密与防范、远程攻击入侵网站与防范、网站源代码安全分析与测试等。《网站入侵与脚本攻防修炼》尤其对网站脚本漏洞原理进行细致的分析,帮助网站管理员、安全人......一起来看看 《网站入侵与脚本攻防修炼》 这本书的介绍吧!
在线进制转换器
各进制数互转换器
RGB CMYK 转换工具
RGB CMYK 互转工具