首页 > 代码库 > js 找数组中的最值

js 找数组中的最值

背景: 2个数组以下 , 比如  [[4, 9, 1, 3], [13, 35, 18, 26], [32, 35, 97, 39], [1000000, 1001, 857, 1]]

找最值的时候,我一开始想用两个 for 循环比较每一个数组中的每一个数组的大小,然后保留最大值(最小值),最后再把它们组成一个新数组。

// 2
function largestOfFour(arr) {
    var maxArr,
        temp=[], // .push()是操作数组
        z;
    for (var i = 0; i < arr.length; i++) {
        z=arr[i][0]; // 重点... 用来比较、保存
        for (var j = 0; j < arr[i].length-1; j++) { // j+1了,防止超出,得-1
            if (arr[i][j+1] > z ){
                z = arr[i][j+1];
            }
        }
        temp.push(z);
    }
    console.log(temp);
}

largestOfFour([[1114, 5, 321, 3], [13, 127, 18, 26], [322, 35, 37, 39], [13000, 1001, 857, 1]]);

缺少基础,写出上面的代码颇有曲折,参考了很久排序算法(主要是选择排序)才慢慢的写出来....

------

中间其实是做不出来了,于是我就百度, 查到了js 里是可以自己算最大值最小值的.....

就是 Math.max()  Math.min() 

数组要放在其中使用的话,要用 apply() 才行

他们是这样举例的...

先是举例用了用 for 循环

var arr=[5,7,9,1]
// alert(Math.max(arr))     这样是不行的。一定要这样写
function getMax(arr){
    var arrLen=arr.length;
    for(var i=0,ret=arr[0];i<arrLen;i++){
        ret=Math.max(ret,arr[i]);       
    }
    return ret;
}

然后是 apply()


var arr=[5,7,9,1];
function getMax2(arr){
    return Math.max.apply(null,arr);
}

...

简洁了很多..很多

然后用到我的题目中呢就是这样的

function largestOfFour(arr){
    var newArr = [],
        temp;
    for (var i = 0; i < arr.length; i++) {
        temp = Math.min.apply(null,arr[i]);
        newArr.push(temp);
    }
    return newArr;
}
largestOfFour([[1,2,3],[5,6],[9,77]]);

还阔以, 也简洁了许多..

请多指教

js 找数组中的最值