I coded 3 factorial algorithms:
trampoline()
method and it works fine as I expect.def factorial
factorial = { BigInteger n ->
if (n == 1) return 1
n * factorial(n - 1)
}
factorial(1000) // stack overflow
factorial = { Integer n, BigInteger acc = 1 ->
if (n == 1) return acc
factorial(n - 1, n * acc)
}
factorial(1000) // stack overflow, why?
factorial = { Integer n, BigInteger acc = 1 ->
if (n == 1) return acc
factorial.trampoline(n - 1, n * acc)
}.trampoline()
factorial(1000) // It works.
Starting with version 2.3 Groovy supports tail recursion with the @TailRecursive annotation for methods: https://blog.mrhaki.com/2014/05/groovy-goodness-more-efficient-tail.html