对于计算如1+2+3+....+n和1*2*3*4*5...*n等问题
我们的方法很多,可以使用这个累加器,递归方法解决。
在nodeJS中实践一下这个reduce方法来解决
下面是一个数组的解决案
C:\Users\kai.feng>node
> Function.prototype.method = function(name,func){
... this.prototype[name] = func;
... return this ;
... }
[Function]
> Array.method("reduce",function(func,value){
... var i = 0;
... for (i = 0 ; i < this.length ; i++) {
..... value = func(this[i],value);
..... }
... return value ;
... })
[Function: Array]
> var p = [1,2,3,4,5,6]
undefined
> var add = function(x,y){
... return x+y;
... }
undefined
> p.reduce(add,0)
21
> var nn = function(x,y){
... return x*y ;
... }
undefined
> p.reduce(nn,1)
720
>
对于数字有一个粗糙的案
> Number.method("reduce",function(func,value){
... var i = 1;
... for (i = 1 ; i <= this ; i++) {
..... value = func(i,value);
..... }
... return value ;
... })
[Function: Number]
>
> var N = 5;
undefined
> N.reduce(nn,1)
120
>