1. 程式人生 > >返回數組中的最大數 -freeCodeCamp

返回數組中的最大數 -freeCodeCamp

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