您的位置:首页 > 编程语言 > Go语言

A Tour of Go---Exercise: Fibonacci closure

2016-10-04 10:44 597 查看


练习:斐波纳契闭包

https://tour.golang.org/moretypes/26

Implement a 
fibonacci
 function
that returns a function (a closure) that returns successive fibonacci
numbers (0, 1, 1, 2, 3, 5, ...).

实现一个 
fibonacci
 函数,返回一个函数(一个闭包)可以返回连续的斐波纳契数。

package main

import "fmt"

// fibonacci 函数会返回一个返回 int 的函数。
func fibonacci() func() int {
pre := -1
sum := 1
return func() int {
pre, sum = sum, pre+sum
return sum
}
}

func main() {
f := fibonacci()
for i := 0; i < 10; i++ {
fmt.Println(f())
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  go