原生Js获取数组中最长的连续数字序列的方法

时间: 2018-04-23阅读: 2015标签: 算法

原始题目:给定一个无序的整数序列, 找最长的连续数字序列。例如:给定[100, 4, 200, 1, 3, 2],最长的连续数字序列是[1, 2, 3, 4]。


js代码如下:

function maxSequence(array, step) {
	var _array = array.slice(), //clone array
		_step = 1,
		_arrayTemp = [],
		i = 0;
	var parseLogic = {
		//result container
		parseResults: [],
		//set value to array,what's the last array of parseResults
		set: function(n) {
			this.parseResults[this.parseResults.length - 1].push(n);
		},
		//get the last array from parseResults
		get: function() {
			return this.parseResults[this.parseResults.length - 1];
		},
		//put a new array in parseResults
		addItem: function() {
			this.parseResults.push([]);
		},
		//sort parseResults
		sortByAsc: function() {
			this.parseResults.sort(function(a, b) {
				return a.length - b.length;
			});
		}
	};
	//check params
	_step = step || _step;
	//sort array by asc
	_array.sort(function(a, b) {
		return a - b;
	});
	//remove repeat of data
	for(i = 0; i < _array.length; i++) {
		if(_array[i] != _array[i + 1]) {
			_arrayTemp.push(_array[i]);
		}
	}
	_array = _arrayTemp.slice();
	_arrayTemp = [];
	parseLogic.addItem();//parse array
	for(i = 0; i < _array.length; i++) {
		if(_array[i] + _step == _array[i + 1]) {
			parseLogic.set(_array[i]);
			continue;
		}
		if(_array[i] - _step == _array[i - 1]) {
			parseLogic.set(_array[i]);
			parseLogic.addItem();
		}
	}
	parseLogic.sortByAsc();//sort result
	return parseLogic.get();//get the max sequence
}


方法名称:

maxSequence(array,step)

参数说明:

array:要查找的数组。必要。
step:序列步长(增量)。可选,默认为1。

返回值:

此方法不会改变传入的数组,会返回一个包含最大序列的新数组。

调用示例:

console.log(maxSequence([5,7,2,4,0,3,9],1)); //return [2,3,4,5]
console.log(maxSequence([5,7,2,4,0,3,9],2)); //return [5,7,9]


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

链接: http://www.fly63.com/article/detial/697

js算法_奇偶分割数组

分割一个整数数组,使得奇数在前偶数在后。 比如:给定 [1, 2, 3, 4],返回 [1, 3, 2, 4]。思路分析:排序好的数组:找到奇数进行操作。乱序的数组:使用sort方法进行排序+提取奇数

js字典树算法_Trie树(字典树)实现与应用

字典树又称Trie树、前缀字,单词查找树,是一种树形结构,是一种哈希树的变种,是一种用于快速检索的多叉树结构。 字典树是处理字符串常见的一种树形数据结构

js从数组取出 连续的 数字_实现一维数组中连续数字分成几个连续的数字数组

使用原生js将一维数组中,包含连续的数字分成一个二维数组,这篇文章分2种情况介绍如何实现?1、过滤单个数字;2、包含单个数字。

PHP 迁移 Mcrypt 至 OpenSSL 加密算法详解

对称加解密算法中,当前最为安全的是 AES 加密算法(以前应该是是 DES 加密算法),PHP 提供了两个可以用于 AES 加密算法的函数簇:Mcrypt 和 OpenSSL。其中 Mcrypt 在 PHP 7.1.0 中被 Deprecated,在 PHP 7.2.0 中被移除,所以即可起你应该使用 OpenSSL 来实现 AES 的数据加解密。

js生成32位uuid算法总汇_js 如何生成uuid?

GUID是一种由算法生成的二进制长度为128位的数字标识符。GUID 的格式为“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,其中的 x 是 0-9 或 a-f 范围内的一个32位十六进制数。在理想情况下,任何计算机和计算机集群都不会生成两个相同的GUID。

JavaScript数据结构与算法-String

给定一个字符串,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。主要就是用到了数组的 split 、 reverse 、 join 、 map 方法,原理:就是把字符串变成数组

Js队列的实现与应用

队列与栈不同,它遵从先进先出(FIFO——First In First Out)原则,新添加的元素排在队列的尾部,元素只能从队列头部移除。

从js讲解时间复杂度和空间复杂度

今天有同事在检查代码的时候,由于函数写的性能不是很好,被打回去重构了,细思极恐,今天和大家分享一篇用js讲解的时间复杂度和空间复杂度的博客;复杂度的表示方式之前有看过的,你可能会看到这么一串东西

最短编辑距离

1.第一行表示从ME到空字符所要删除的字符的所以情况 2.第一列表示从空字符到MY所需要插入字符的所有情况 3.斜箭头表示相同字符不需要替换,不相同字符所有替换次数的所有情况

js求水仙花数_JavaScript可自定义范围打印水仙花数

水仙花数是指一个 n 位正整数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身(例如:1^3 + 5^3+ 3^3 = 153)。这篇文章主要介绍js实现生成自定义范围内的水仙花数。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!