Skip to Content
Learning Functional Programming in Go
book

Learning Functional Programming in Go

by Lex Sheehan
November 2017
Intermediate to advanced
670 pages
17h 35m
English
Packt Publishing
Content preview from Learning Functional Programming in Go

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 ...

Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Start your free trial

You might also like

Learning Functional Programming

Learning Functional Programming

Jack Widman

Publisher Resources

ISBN: 9781787281394Supplemental Content