scala - Scala 中的匿名递归函数

标签 scala recursion anonymous-function

有没有办法在 Scala 中编写递归的匿名函数?我正在考虑这样的事情:

((t: Tree) => {
    print(t.value);
    for (c <- t.children)
        thisMethod(c)
})(root)

(相关问题:Which languages support *recursive* function literals / anonymous functions?)

最佳答案

如您发布的链接中所述。您可以使用 Y 组合器。这是示例:

scala> def fix[A,B](f: (A=>B)=>(A=>B)): A=>B = f(fix(f))(_)
fix: [A,B](f: ((A) => B) => (A) => B)(A) => B

scala> val fact = fix[Int,Int](f => a => if(a<=0) 1 else f(a-1) * a)
fact: (Int) => Int = <function1>

scala> fact(12)
res0: Int = 479001600

请注意,它不适用于大数字。 小心尾部调用优化。

关于scala - Scala 中的匿名递归函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5337464/

相关文章:

java - Scala foreach 返回

c# - 优先顺序如何影响递归方法?

C++模板用递归实现循环

javascript - JQuery getScript() 从 curl.js 模块调用匿名函数

JavaScript 从匿名函数中读取私有(private)变量

matlab - 在没有循环的情况下访问结构中的数据

scala - 使用 Gatling 进行调试 - 如果状态为 500,则打印 ln

scala - 如何使用 Scala Actors 的同步发送来摆脱向下转换?

scala - 在 Scala 中,如何解决 TraversableLike.toIterator 效率低下的中间流

Java - 无法摆脱这种递归方法