3 回答
TA贡献1803条经验 获得超6个赞
更改您的函数以将 res 返回为此:
return func () int {
res := y
y = z
z = res + z
return res
}
这样,您首先输出初始值,然后计算下一个值。您当前的解决方案会在返回之前覆盖初始值。
TA贡献2041条经验 获得超4个赞
例如,
package main
import "fmt"
// fibonacci returns a function that returns
// successive Fibonacci numbers.
func fibonacci() func() int {
a, b := 0, 1
return func() (f int) {
if a < 0 {
panic("overflow")
}
f, a, b = a, b, a+b
return f
}
}
func main() {
f := fibonacci()
for i := 0; i < 10; i++ {
fmt.Println(f())
}
}
游乐场:https://play.golang.org/p/uYHEK_ZgE6K
输出:
0
1
1
2
3
5
8
13
21
34
TA贡献1862条经验 获得超7个赞
如果您添加:
x := y
并将返回语句更改为
return x
您将返回初始y := 0
值,而不是计算值res := y + z
,因此返回序列中较早的值 2 ,给您0, 1, 1, 2, 3, 5, ...
(但我不认为-1, 1
初始化器是黑客。)
- 3 回答
- 0 关注
- 117 浏览
添加回答
举报