JavaScript专题之怎样求数组的最大值和最小值

JavaScritpt 专题系列第八篇,解说多种体式格局求数组的最大值和最小值

媒介

掏出数组中的最大值或许最小值是开辟中常见的需求,但你能想出几种要领来完成这个需求呢?

Math.max

JavaScript 供应了 Math.max 函数返回一组数中的最大值,用法是:

Math.max([value1[,value2, ...]])

值得注重的是:

  1. 假如有任一参数不能被转换为数值,则效果为 NaN。

  2. max 是 Math 的静态要领,所以应当像如许运用:Math.max(),而不是作为 Math 实例的要领 (简朴的来讲,就是不运用 new )

  3. 假如没有参数,则效果为 -Infinity (注重是负无穷大)

而我们须要剖析的是:

1.假如任一参数不能被转换为数值,这就意味着假如参数能够被转换成数字,就是能够举行比较的,比方:

Math.max(true, 0) // 1
Math.max(true, '2', null) // 2
Math.max(1, undefined) // NaN
Math.max(1, {}) // NaN

2.假如没有参数,则效果为 -Infinity,对应的,Math.min 函数,假如没有参数,则效果为 Infinity,所以:

var min = Math.min();
var max = Math.max();
console.log(min > max);

了解了 Math.max 要领,我们以求数组最大值的为例,思索有哪些要领能够完成这个需求。

原始要领

最最原始的要领,莫过于轮回遍历一遍:

var arr = [6, 4, 1, 8, 2, 11, 23];

var result = arr[0];
for (var i = 1; i < arr.length; i++) {
    result =  Math.max(result, arr[i]);
}
console.log(result);

reduce

既然是经由过程遍历数组求出一个最终值,那末我们就能够运用 reduce 要领:

var arr = [6, 4, 1, 8, 2, 11, 23];

function max(prev, next) {
    return Math.max(prev, next);
}
console.log(arr.reduce(max));

排序

假如我们先对数组举行一次排序,那末最大值就是末了一个值:

var arr = [6, 4, 1, 8, 2, 11, 23];

arr.sort(function(a,b){return a - b;});
console.log(arr[arr.length - 1])

eval

Math.max 支撑传多个参数来举行比较,那末我们如何将一个数组转换成参数传进 Math.max 函数呢?eval 就是一种

var arr = [6, 4, 1, 8, 2, 11, 23];

var max = eval("Math.max(" + arr + ")");
console.log(max)

apply

运用 apply 是另一种。

var arr = [6, 4, 1, 8, 2, 11, 23];
console.log(Math.max.apply(null, arr))

ES6 …

运用 ES6 的扩大运算符:

var arr = [6, 4, 1, 8, 2, 11, 23];
console.log(Math.max(...arr))

有更多的要领迎接留言哈~

专题系列

JavaScript专题系列目次地点:https://github.com/mqyqingfeng/Blog

JavaScript专题系列估计写二十篇摆布,重要研讨一样平常开辟中一些功用点的完成,比方防抖、撙节、去重、范例推断、拷贝、最值、扁平、柯里、递归、乱序、排序等,特点是研(chao)究(xi) underscore 和 jQuery 的完成体式格局。

假如有毛病或许不严谨的处所,请务必赋予斧正,非常谢谢。假如喜好或许有所启示,迎接 star,对作者也是一种勉励。

    原文作者:冴羽
    原文地址: https://segmentfault.com/a/1190000010250128
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞