blob: e7c29a51a85dd0c26bfc643c575528599e4121e3 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
object Recursion {
// Tail recursion - tail calls
// the function calls itself (or another one) as last action
// -> the function's stack frame can be reused!
// -> this is as efficient as a loop
def gcd(a: Int, b: Int): Int =
if (b == 0) a else gcd(b, a % b)
println(gcd(21, 56))
// there is still the multiplication to be performed
// -> the stack frame can't be reused
def fact(n: Int): Int =
if (n == 0) 1 else n * fact(n - 1)
println(fact(4))
// tail recursive version of factorial
def factr(n: Int): Int = {
def factIter(acc: Int, n: Int): Int =
if (n == 0) acc else factIter(acc * n, n - 1)
factIter(1, n)
}
def run = println(factr(4))
}
|