Y-Combinator re-examined

Let’s look at another Y-Combinator example in Go to improve our grasp of the topic. Remember the Fibonacci function in Chapter 1, Pure Functional Programming in Go? It looked like this:

func fib(x int) int {    if x == 0 {        return 0    } else if x <= 2 {        return 1    } else {        return fib(x-2) + fib(x-1)    }}

If it passes a 0, 1, or 2, it simply returns a value (0 or 1). Otherwise, it will call itself (recursion) with two functions that look like this--fib(x-2) + fib(x-1). Since values are continually being decremented by two or one, processing will eventually complete, at which time the accumulated values will be summed up.

The following diagram illustrates this recursive processing. The orange and red boxes highlight functions ...

Get Learning Functional Programming in Go now with the O’Reilly learning platform.

O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.