JS数组求和的常用方法总结【5种方法】


Posted in Javascript onJanuary 14, 2019

本文实例总结了JS数组求和的常用方法。分享给大家供大家参考,具体如下:

题目描述

计算给定数组 arr 中所有元素的总和

输入描述:

数组中的元素均为 Number 类型

输入例子:

sum([ 1, 2, 3, 4 ])

输出例子:

10

方法1. 不考虑算法复杂度,用递归做:

function sum(arr) {
  var len = arr.length;
  if(len == 0){
    return 0;
  } else if (len == 1){
    return arr[0];
  } else {
    return arr[0] + sum(arr.slice(1));
  }
}

方法2. 常规循环:

function sum(arr) {
  var s = 0;
  for (var i=arr.length-1; i>=0; i--) {
    s += arr[i];
  }
  return s;
}

方法3. 函数式编程 map-reduce:

function sum(arr) {
  return arr.reduce(function(prev, curr, idx, arr){
    return prev + curr;
  });
}

方法4. forEach遍历:

function sum(arr) {
  var s = 0;
  arr.forEach(function(val, idx, arr) {
    s += val;
  }, 0);
 
  return s;
};

方法5. eval:

function sum(arr) {
  return eval(arr.join("+"));
};
//测试输出运行结果:
console.log(sum([ 1, 2, 3, 4 ]))

使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码,可得如下运行结果:

JS数组求和的常用方法总结【5种方法】

感兴趣的朋友可以动手测试一下上述代码。

更多关于JavaScript相关内容还可查看本站专题:《JavaScript数组操作技巧总结》、《JavaScript字符与字符串操作技巧总结》、《JavaScript遍历算法与技巧总结》、《JavaScript排序算法总结》、《JavaScript查找算法技巧总结》、《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript错误与调试技巧总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
借助script进行Http跨域请求:JSONP实现原理及代码
Mar 19 Javascript
YUI模块开发原理详解
Nov 18 Javascript
使用apply方法实现javascript中的对象继承
Dec 16 Javascript
绑定回车enter事件代码
May 18 Javascript
js中数组结合字符串实现查找(屏蔽广告判断url等)
Mar 30 Javascript
jQuery实现鼠标悬停3d菜单展开动画效果
Jan 19 Javascript
vue 和vue-touch 实现移动端左右导航效果(仿京东移动站导航)
Apr 22 Javascript
javascript 中关于array的常用方法详解
May 05 Javascript
微信小程序实现滑动删除效果
May 19 Javascript
webpack踩坑之路图片的路径与打包
Sep 05 Javascript
微信小程序支付PHP代码
Aug 23 Javascript
《javascript设计模式》学习笔记七:Javascript面向对象程序设计组合模式详解
Apr 08 Javascript
JS实现根据数组对象的某一属性排序操作示例
Jan 14 #Javascript
vue项目中使用vue-i18n报错的解决方法
Jan 13 #Javascript
vscode下vue项目中eslint的使用方法
Jan 13 #Javascript
jQuery实现的中英文切换功能示例
Jan 11 #jQuery
JavaScript寄生组合式继承原理与用法分析
Jan 11 #Javascript
JavaScript常见继承模式实例小结
Jan 11 #Javascript
JavaScript惰性求值的一种实现方法示例
Jan 11 #Javascript
You might like
可以文本显示的公告栏的js代码
2007/03/11 Javascript
JavaScript 加号(+)运算符号
2009/12/06 Javascript
VBS通过WMI监视注册表变动的代码
2011/10/27 Javascript
jQuery 无限级菜单的简单实例
2014/02/21 Javascript
javascript获取隐藏元素(display:none)的高度和宽度的方法
2014/06/06 Javascript
jquery实现在光标位置插入内容的方法
2015/02/05 Javascript
功能强大的Bootstrap组件(结合js)
2016/08/03 Javascript
深入学习 JavaScript中的函数调用
2017/03/23 Javascript
理解Angular的providers给Http添加默认headers
2017/07/04 Javascript
JS表单传值和URL编码转换
2018/03/03 Javascript
微信小程序之swiper轮播图中的图片自适应高度的方法
2018/04/23 Javascript
微信小程序swiper实现滑动放大缩小效果
2018/11/15 Javascript
迅速了解一下ES10中Object.fromEntries的用法使用
2019/03/05 Javascript
vue+element实现打印页面功能
2019/05/20 Javascript
ES6 Array常用扩展的应用实例分析
2019/06/26 Javascript
微信小程序入口场景的问题集合与相关解决方法
2019/06/26 Javascript
Vue项目页面跳转时浏览器窗口上方显示进度条功能
2020/03/26 Javascript
Vue实现背景更换颜色操作
2020/07/17 Javascript
解决Vue-Router升级导致的Uncaught (in promise)问题
2020/08/07 Javascript
[01:05:52]DOTA2-DPC中国联赛 正赛 Ehome vs Aster BO3 第一场 2月2日
2021/03/11 DOTA
django搭建项目配置环境和创建表过程详解
2019/07/22 Python
Django中使用session保持用户登陆连接的例子
2019/08/06 Python
Django3.0 异步通信初体验(小结)
2019/12/04 Python
opencv3/python 鼠标响应操作详解
2019/12/11 Python
使用Python三角函数公式计算三角形的夹角案例
2020/04/15 Python
Python实现一个优先级队列的方法
2020/07/31 Python
python搜索算法原理及实例讲解
2020/11/18 Python
使用html5新特性轻松监听任何App自带返回键的示例
2018/03/13 HTML / CSS
Vans奥地利官方网站:美国原创极限运动潮牌
2018/09/30 全球购物
华为慧通面试题
2012/09/11 面试题
文件中有一组整数,要求排序后输出到另一个文件中
2012/01/04 面试题
汽车专业毕业生自荐信
2013/11/03 职场文书
餐厅保洁员岗位职责
2015/04/10 职场文书
爱国之歌(8首)
2019/09/29 职场文书
导游词之青岛太清宫
2019/12/13 职场文书
SpringBoot整合JWT的入门指南
2021/06/29 Java/Android