查找数组中最大值的5种方法

 

文章来源:https://www.cnblogs.com/qdwz/p/13710609.html

1.排序法

首先我们给数组进行排序,可以按照从小到大的顺序来排,排序之后的数组中第一个和最后一个就是我们想要获取的最小值和最大值。

排序我们会用到数组的 sort 方法。

复制代码
var arr = [12,56,25,5,82,51,22];

arr.sort(function (a, b) {
  return a-b;
}); // [5,12,22,25,51,56]

es6写法: arr.sort((a,b) => a-b) var min = arr[0]; // 5 var max = arr[arr.length - 1]; // 56
复制代码

 

2.假设法

假设当前数组中的第一个值是最大值,然后拿这个最大值和后面的项逐一比较,如果后面的某一个值比假设的值还大,说明假设错了,我们把假设的值进行替换。最后得到的结果就是我们想要的。

复制代码
// 获取最大值:

var arr = [22,13,6,55,30];
var max = arr[0];

for(var i = 1; i < arr.length; i++) {
   var cur = arr[i];
   cur > max ? max = cur : null
}

console.log(max); // 55

// 获取最小值:

var arr = [22,13,6,55,30];
var min = arr[0];

for(var i = 1; i < arr.length; i++) {
  var cur = arr[i];
  cur < min ? min = cur : null
}
console.log(min)  // 6
复制代码

 

3. 使用 Math 中的 max/min 方法

可以使用apply来实现。apply传入的是一个数组。

复制代码
var arr = [22,13,6,55,30];

var max = Math.max.apply(null, arr);
var min = Math.min.apply(null, arr);

console.log(max, min) // 55,6
复制代码

 

4. 使用ES6的扩展运算符

var arr = [22,13,6,55,30];
 
 console.log(Math.max(...arr)); // 55

 

posted @ 2021-09-29 14:48  星空飘渺  阅读(5772)  评论(0编辑  收藏  举报