首页 > 其他 > 详细

Exercise: Fibonacci closure

时间:2016-05-24 13:36:09      阅读:299      评论:0      收藏:0      [点我收藏+]

Exercise: Fibonacci closure

题目:

Lets have some fun with functions.

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

代码:

package main

import "fmt"

// fibonacci is a function that returns
// a function that returns an int.
func fibonacci() func() int {
	a, b, c := 0, 1, 0
	return func () int {
		c, a, b = a, b, a+b
		return c
	}
}

func main() {
	f := fibonacci()
	for i := 0; i < 10; i++ {
		fmt.Println(f())
	}
}

运行结果:

0
1
1
2
3
5
8
13
21
34

  

  

Exercise: Fibonacci closure

原文:http://www.cnblogs.com/chpx/p/5523010.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!