在没有通道的情况下同时计算斐波那契,但指针不起作用

在这个练习中,我试图计算斐波那契数,但是通过生成 goroutine 并通过参数中的指针发回结果,但我做错了,请帮忙


package main


import (

    "fmt"

)


func fib(n int, p *int) {

    fmt.Println(n)

    var a, b int

    if n > 1 {

        go fib(n-1, &a)

        go fib(n-2, &b)

        *p = a + b

    } else {

        *p = n

    }

    fmt.Println(*p)


}


func main() {

    c := -1

    go fib(5, &c)

    fmt.Println(c)

}


大话西游666
浏览 90回答 1
1回答

狐的传说

只是为了不留下未回答的问题(可能不是最好的,但可以完成练习)package mainimport (    "fmt"    "sync")func fib(n int, p *int, wg1 *sync.WaitGroup) {    // fmt.Println(n)    a, b := -1, -1    var wg sync.WaitGroup    if n > 1 {        wg.Add(1)        go fib(n-1, &a, &wg)        wg.Add(1)        go fib(n-2, &b, &wg)        wg.Wait()        *p = a + b    } else {        *p = n    }    wg1.Done()    // fmt.Println(*p)}func main() {    c := -1    var wg sync.WaitGroup    wg.Add(1)    go fib(30, &c, &wg)    wg.Wait()    fmt.Println(c)}
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go