亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

我應該在代碼中更改什么來生成從 0 1 1 開始的斐波那契數列

我應該在代碼中更改什么來生成從 0 1 1 開始的斐波那契數列

Go
斯蒂芬大帝 2023-07-04 19:04:28
我搜索過較舊的問題,有很多。但是我找不到我的案例的答案。func fibonacci() func() int {    y := 0    z := 1    return func () int {        res := y + z        y = z        z = res        return res    }}func main() {    f := fibonacci()    for i := 0; i < 10; i++ {        fmt.Println(f())    }}這會產生 1 2 3 5 8我應該改變什么(盡可能少)才能得到 0 1 1 2 3 5 8 ?實際上我設法解決了這個問題,如果最初y是z這樣的:    y := -1    z := 1但這是一個幸運的黑客,我想要一個合乎邏輯的解決方案。
查看完整描述

3 回答

?
慕碼人8056858

TA貢獻1803條經驗 獲得超6個贊

更改您的函數以將 res 返回為此:


 return func () int {


    res := y

    y = z

    z = res + z


    return res


}

這樣,您首先輸出初始值,然后計算下一個值。您當前的解決方案會在返回之前覆蓋初始值。


查看完整回答
反對 回復 2023-07-04
?
縹緲止盈

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


查看完整回答
反對 回復 2023-07-04
?
牧羊人nacy

TA貢獻1862條經驗 獲得超7個贊

如果您添加:

x := y

并將返回語句更改為

return x

您將返回初始y := 0值,而不是計算值res := y + z,因此返回序列中較早的值 2 ,給您0, 1, 1, 2, 3, 5, ...

(但我不認為-1, 1初始化器是黑客。)


查看完整回答
反對 回復 2023-07-04
  • 3 回答
  • 0 關注
  • 166 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號