Skip to content

Instantly share code, notes, and snippets.

@dz1984
Created March 23, 2014 07:51
Show Gist options
  • Save dz1984/9720020 to your computer and use it in GitHub Desktop.
Save dz1984/9720020 to your computer and use it in GitHub Desktop.
"A Tour of Go"
/*
Exercise: Fibonacci closure
Let's have some fun with functions.
Implement a fibonacci function that returns a function (a closure) that returns successive fibonacci numbers.
*/
package main
import "fmt"
// fibonacci is a function that returns
// a function that returns an int.
func fibonacci() func() int {
f0,f1,fn := 0,1,0
return func() int {
fn = f0+f1
f0 = f1
f1 = fn
return fn
}
}
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