标签:求和 函数式 输出 describe pre 方法 递归 编程 类型
题目描述
数组中的元素均为 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("+")); };
标签:求和 函数式 输出 describe pre 方法 递归 编程 类型
原文地址:https://www.cnblogs.com/lixiaoyao-1/p/8985723.html