JavaScript數(shù)組求和的方法:1、利用遞歸,讓數(shù)組元素不斷相加求和;2、利用for循環(huán),讓數(shù)組元素不斷相加求和;3、利用forEach遍歷,讓數(shù)組元素不斷相加求和;4、使用“eval(arr.join("+"))”語(yǔ)句求和。
本教程操作環(huán)境:windows7系統(tǒng)、javascript1.8.5版、Dell G3電腦。
JavaScript數(shù)組求和
方法1. 不考慮算法復(fù)雜度,用遞歸做:
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. 常規(guī)循環(huán):
function sum(arr) { var s = 0; for (var i=arr.length-1; i>=0; i--) { s += arr[i]; } return s; }
方法3. 函數(shù)式編程 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("+")); };
//測(cè)試輸出運(yùn)行結(jié)果: console.log(sum([ 1, 2, 3, 4 ]))
可得如下運(yùn)行結(jié)果:
【