源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

分享JS数组求和与求最大值的方法

  • 时间:2021-10-24 13:07 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:分享JS数组求和与求最大值的方法
[b]前言[/b] 面试遇到一个问题:JS数组求和函数。我第一想到的就是数组循环。然而我觉得面试官问这个问题一定不是想考这个人人皆知的方法。当时机智的我竟然想到了递归函数不断加和数组的项,然而折腾了好久都没调好方法,事实证明这并不是最优解。最后面试官问我有没有见过[code]reduce()[/code],真木有哇。所以回来查资料,[code]Array.reduce()[/code]是ES5新增的新属性,相似的还有[code]Array.reduceRight()。[/code] 下文来总结一下数组求和的方法。 [b]最粗暴的方法:循环获取[/b] 通过for循环一项项地加和。看代码:
Array.prototype.sum = function (){
 var result = 0;
 for(var i = 0; i < this.length; i++) {
  result += this[i];
 }
 return result;
};

[1,4,7,2,10].sum(); // 24
[b]使用reduce方法[/b] 利用[code]reduce[/code]方法,可以写一个数组求和的[code]sum[/code]方法。 [code]reduce()[/code]方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终为一个值。 [b]reduce的语法:[/b]
array.reduce(callback[, initialValue]);
[code]callback[/code]函数接受4个参数:[code]previousValue[/code](上次调用回调返回的值)、[code]currentValue[/code](当前被处理的元素)、[code]index[/code](索引)以及数组本身(第一次调用 [code]callback[/code]的第一个参数),执行数组中每个值的函数。 [code]initialValue[/code]参数可选,表示初始值;[code]initialValue[/code]参数若指定,则当作最初使用的[code]previous[/code]值,如果缺省,则使用数组的第一个元素作为[code]previous[/code]初始值,同时[code]current[/code]往后排一位。
Array.prototype.sum = function (){
 return this.reduce(function (partial, value){
  return partial + value;
 })
};
[1,4,7,2,10].sum(); // 24
相比第一种方法,使用[code]reduce()[/code]方法的效率更高。 这两种方法的效率比较可以直接在函数运行前后分别调用[code]new Date()[/code]获取即时时间,从而通过时间差比较执行时间。这里就不比较了,因为每个人的执行环境差异较大。测试结果是[code]reduce()[/code]方法的执行时间更短。 [b]JS数组求和函数,并求出数组中的最大值[/b] 实例代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />

<title>编程素材网_js数组求和和最大值方法_编程素材网网</title>

<meta name="keywords" content="站长,网页特效,网页特效代码,js特效,js脚本,脚本,广告代码,jb51.net,www.1sucai.cn,编程素材网网" />

<meta name="description" content="www.1sucai.cn,编程素材网网,站长必备js特效及广告代码。大量高质量js特效,提供高质量广告代码下载,尽在编程素材网网" />

</head>

<body>

<a href="http://www.1sucai.cn/">编程素材网网</a>,站长必备的高质量网页特效和广告代码。jb51.net,站长js特效。<hr>

<script type="text/javascript">

//求和

Array.prototype.sum = function () {

 for (var sum = i = 0; i < this.length; i++)sum += parseInt(this[i]);

  return sum ;

};

//求最大值

Array.prototype.maxima = function () {

 for (var i = 0, maxValue = Number.MIN_VALUE; i < this.length; i++)parseInt(this[i]) > maxValue && (maxValue = this[i]);

 return maxValue;

};

//应用

var arr = [1,21,3,4,22,45,60,7,32];

alert(arr.join("+") + "=" + arr.sum()); alert(arr.join("|") + "中, 最大的数是:" + arr.maxima());

</script>

</body>

</html>
以上就是本文的全部内容,希望对大家使用JavaScript有所帮助哦,如果有疑问的话欢迎留言讨论,小编会及时回复大家的。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部