Skip to content

Instantly share code, notes, and snippets.

@andramarkov
Forked from tetsuok/fibonacci_closure.go
Created February 20, 2018 04:04
Show Gist options
  • Save andramarkov/6fa80a9841f7fb82d78d3fb1cf297d55 to your computer and use it in GitHub Desktop.
Save andramarkov/6fa80a9841f7fb82d78d3fb1cf297d55 to your computer and use it in GitHub Desktop.
An answer of the exercise: Fibonacci closure on a tour of Go
package main
import "fmt"
// Very naive answer.
// fibonacci is a function that returns
// a function that returns an int.
func fibonacci() func() int {
n := 0
a := 0
b := 1
c := a + b
return func() int {
var ret int
switch {
case n == 0:
n++
ret = 0
case n == 1:
n++
ret = 1
default:
ret = c
a = b
b = c
c = a + b
}
return ret
}
}
func main() {
f := fibonacci()
for i := 0; i < 10; i++ {
fmt.Println(f())
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment