二分法求数组最大最小_JavaScript之如何求数组的最大值和最小值

上次给大家分享了从零事项jQuery的extend,今天跟大家分享下如何求数组的最大值和最小值。

取出数组中的最大值或者最小值是开发中常见的需求,但你能想出几种方法来实现这个需求呢?

1. Math.max

JavaScript 提供了 Math.max 函数返回一组数中的最大值,用法是:Math.max([value1[,value2, ...]])。

值得注意的是:1)如果有任一参数不能被转换为数值,则结果为 NaN;2)max 是 Math 的静态方法,所以应该像这样使用:Math.max(),而不是作为 Math 实例的方法 (简单的来说,就是不使用 new);3)如果没有参数,则结果为 -Infinity (注意是负无穷大)。

而我们需要分析的是:如果任一参数不能被转换为数值,这就意味着如果参数可以被转换成数字,就是可以进行比较的,比如:

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

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

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

了解了 Math.max 方法,我们以求数组最大值的为例,思考有哪些方法可以实现这个需求。

2. 原始方法

最最原始的方法,莫过于循环遍历一遍:

5633d22990c526c02b9c992cb8f22dcd.png

既然是通过遍历数组求出一个最终值,那么我们就可以使用 reduce 方法:

f3706e4b42d9963933a609bbb88ee926.png

3. 排序

如果我们先对数组进行一次排序,那么最大值就是最后一个值:

048d64867320e29546e8a1fe85c0cfe7.png

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

bf2417612d4c2a40995d96936f319ee6.png

使用 apply 是另一种:

cd6d1238bd08b6317cdd0f928e6d04ed.png

别忘了还有 ES6 的扩展运算符:

a6708d82738076945e5074599e31ff77.png

学习相关推荐(编程必备辅助):

①:搜索关注公众号“只会写BUG”,分享更多干货知识,资讯,教程等

②:海量编程类资料零基础到高级亟待领取!!!

如果觉得对你有一丢丢帮助,麻烦动动你的小手指【关注】一下上面的公众号吧,或者【转发】让更多人看到该文章。大家也可积极后台给我留言,多多交流,共同进步。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值