返回數組中的最大數 -freeCodeCamp
阿新 • • 發佈:2017-11-18
pan () nbsp out lar 當前 [] sort 應該 應該返回
找出多個數組中的最大數
右邊大數組中包含了4個小數組,分別找到每個小數組中的最大值,然後把它們串聯起來,形成一個新數組。
給出的數組如下:
largestOfFour([[4, 5, 1, 3], [13, 27, 18, 26], [32, 35, 37, 39], [1000, 1001, 857, 1]])
應該返回一個數組
largestOfFour([[13, 27, 18, 26], [4, 5, 1, 3], [32, 35, 37, 39], [1000, 1001, 857, 1]])
應該返回 [27,5,39,1001]
.
largestOfFour([[4, 9, 1, 3], [13, 35, 18, 26], [32, 35, 97, 39], [1000000, 1001, 857, 1]])
[9, 35, 97, 1000000]
.
分析需求:
其實這個題很簡單,我們只要把數組進行循環,然後每一項做一個排序,返回第0個就可以;
代碼如下:
function largestOfFour(arr) { var newArr=[]; for(var i=0;i<arr.length;i++){ arr[i].sort(function(a,b){ return b-a; //對每一個數組進行從大到小的排序}) newArr.push(arr[i][0]); //把每一個數組中的最大值放入新數組 } return newArr; } largestOfFour([[4, 5, 1, 3], [13, 27, 18, 26], [32, 35, 37, 39], [1000, 1001, 857, 1]]); //返回[5,27,39,1001]
我們在數組的原型上添加一個min和max方法來判斷當前數組的最大值和最小值
min方法:
Array.prototype.min = function(){ var min = this[0]; for(var i=0;i<this.length;i++){ if(this[i]<min){ //如果當前值小於前一個這個值就被當作最小值 min=this[i]; } } return min; }
max方法同理:
Array.prototype.max = function (){ var max = this[0]; for(var i=0;i<this.length;i++){ if(this[i]>max){ max=this[i]; } } return max; }
為避免沖突,可以檢測一下Array的原型中有沒有這個方法
if(Array.prototype.min == "undefined"){ //再添加方法 }
返回數組中的最大數 -freeCodeCamp