원제:
정렬되지 않은 정수 시퀀스가 주어지면 연속된 숫자의 가장 긴 시퀀스를 찾습니다.
예:
주어진 [100, 4, 200, 1, 3, 2],
가장 긴 연속 숫자는 [1, 2, 3, 4]입니다.
Xiao Cai가 제공한 솔루션:
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 = []; //parse array parseLogic.addItem(); 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(); } } //sort result parseLogic.sortByAsc(); //get the max sequence return parseLogic.get(); }
전화 안내:
메소드 이름:
maxSequence(배열,단계)
매개변수 설명:
array: 검색할 배열입니다. 필요한.
단계: 시퀀스 단계 크기(증분). 선택 사항이며 기본값은 1입니다.
반환 값:
이 메서드는 전달된 배열을 변경하지 않고 가장 큰 시퀀스가 포함된 새 배열을 반환합니다.
통화 예:
maxSequence([5,7,2,4,0,3,9],1); //return [2,3,4,5] maxSequence([5,7,2,4,0,3,9],2); //return [5,7,9]