Go 斐波那契数列

Go Tour 闭包https://tour.go-zh.org/moretypes/26

package main

import "fmt"

// 返回一个“返回int的函数”
func fibonacci() func() int {
	_S1, _S2 := 0, 1
    //可以从0开始打印
    return func() int {
		_tmp := _S1
		_S1, _S2 = _S2, (_S1 + _S2)
		return _tmp
	}

	/*
    //流行写法(打印从1开始)
	return func() int {
		_S1, _S2 = _S2, (_S1 + _S2)
		return _S1
	}
    */
    /*
    //self func
	_index := 0
	return func() int {
		if _index == 0 {
			_index++
			return _S1
		} else if _index == 1 {
			_index++
			return _S2
		} else {
			_index++
			_tmp := _S1
			_S1 = _S2
			_S2 += _tmp
			return _S2
		}
	}
    */
}

func main() {
	f := fibonacci()
	for i := 0; i < 10; i++ {
		fmt.Println(f())
	}
}
//---打印-从0开始-------------
0
1
1
2
3
5
8
13
21
34
//--流行写法-打印-从1开始-------------
1
1
2
3
5
8
13
21
34
55

猜你喜欢

转载自blog.csdn.net/yaoyutian/article/details/89785025