Here you can find the source of reduce(testFunction,initialValue)
// Reduce always returns an array with one item Array.prototype.reduce = function(testFunction,initialValue){ var accumulatedValue,counter; if(this.length == 0){ return this; }else{/*from w w w. ja v a 2 s .co m*/ if(arguments.length == 1){ counter = 1; accumulatedValue = this[0]; }else if(arguments.length >= 2){ counter = 0; accumulatedValue = initialValue; }else{ throw 'Invalid arguments.' } while(counter < this.length){ accumulatedValue = testFunction(accumulatedValue,this[counter]); counter++; } return [accumulatedValue]; } }
'use strict'; Array.prototype.reduce = function(pasteback, initial){ for(var i = 0 , c = this.length , value = arguments.length>1 ? initial : this[i++] ; i<c; i++){ value = pasteback(value, this[i], i, this); return value; ...
Array.prototype.reduce = function(process, initial) { var value = initial; for (var i = 0; i < this.length; i++) { if( ( i === 0 ) && ( value === undefined || value === null )) value = this[0]; continue; value = process( value, this[i] ); ...
Array.prototype.reduce = function(process, initial) { if (initial === undefined) { var slice = this.slice(1); initial = this[0]; var array = slice || this; array.forEach(function(value) { initial = process(initial, value); }); ...
Array.prototype.reduce = function(reducingFunction, initialValue) { var result = initialValue; this.forEach(function(x) { reducingFunction(result, x) }); return result;
Array.prototype.reduce = function(t, fn) { for(var i = 0 ; i < this.length ; i++) { t = fn(t, this[i]) return t
Array.prototype.reduce = function(testFunction,initialValue){ var accumulatedValue,counter; if(this.length == 0){ return this; }else{ if(arguments.length == 1){ counter = 1; accumulatedValue = this[0]; }else if(arguments.length >= 2){ ...
Array.prototype.reduce = function(testFunction,initialValue){ var accumulatedValue,counter; if(this.length == 0){ return this; }else{ if(arguments.length == 1){ counter = 1; accumulatedValue = this[0]; }else if(arguments.length >= 2){ ...
'use strict'; class PrefixTree { constructor() { this.root = {}; insert(str) { Array.prototype.reduce.call(str, (trav, char) => { if (!trav[char]) { trav[char] = {}; ...
Array.prototype.reduceRight = function(aggregate, initial) { const len = this.length; let startIndex = len - 1; if(typeof initial === 'undefined') { initial = this[0]; startIndex = len - 2; for(let i = startIndex; i >= 0; i -= 1) { initial = aggregate(initial, this[i], i, this); ...