首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JavaScript中的递归归约

JavaScript中的递归归约
EN

Stack Overflow用户
提问于 2011-01-11 19:09:13
回答 2查看 6.8K关注 0票数 2

我对JavaScript非常陌生,对它的一些行为也不太了解。我想写一个在Eloquent JavaScript书中找到的reduce函数的递归版本。这是我的代码:

代码语言:javascript
复制
function rec_reduce( fn, base, list ) {
    if( list.length === 0 ) {
        return base;
    }
    else {
        rec_reduce( fn, fn( base, list[ 0 ] ), list.slice( 1 ) );
    }
}
print( rec_reduce( Math.min, 100, [ 5, 3, 7, 2, 6, 5 ] ));

结果是:

代码语言:javascript
复制
undefined

为了看看发生了什么,我放了:

代码语言:javascript
复制
print( base );

作为函数的第一行,结果是:

代码语言:javascript
复制
100
5
3
3
2
2
2
undefined

谁能给我解释一下为什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-01-11 19:11:52

else块中,您必须

代码语言:javascript
复制
return rec_reduce( ... )
票数 8
EN

Stack Overflow用户

发布于 2014-05-29 05:55:36

另一种方法是:

reduce_file.js:

代码语言:javascript
复制
function reduce(arr, func, initv){
      if(arr.length) return reduce(arr.slice(1), func, func(initv, arr[0]))
      else return initv
}
module.exports = reduce

然后你把它当做:

代码语言:javascript
复制
reduce = require('./reduce_file.js')
console.log(reduce([1,2,3,4], function(prev, curr) {
  return prev + curr
}, 0))

结果:

代码语言:javascript
复制
10 

来自1+2+3+4=10

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4656943

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档