第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

Golang 二叉搜索樹算法翻譯

Golang 二叉搜索樹算法翻譯

Go
回首憶惘然 2021-11-08 18:51:57
我是 Golang 的初學(xué)者,正在嘗試構(gòu)建二叉搜索樹。我的源代碼來做到這一點(diǎn):package mainimport (    "fmt"    "math/rand"    "time")type Node struct{    value int    left *Node    right *Node}func insert(root *Node,v int){    if root==nil{        root=&Node{v,nil,nil}    } else if v<root.value{        insert(root.left,v)    } else{        insert(root.right,v)    }}func inTraverse(root *Node){    if (root==nil){        return    }    inTraverse(root.left)    fmt.Printf("%d",root.value)    inTraverse(root.right)}func main() {    var treeRoot *Node    rand.Seed(time.Now().UnixNano())    n:=6    var a[6]int    for i:=0;i<n;i++{        a[i]=rand.Intn(20)+1    }    fmt.Println("Array of integer: ")    for i:=0;i<n;i++{        fmt.Printf("%d ",a[i])    }    fmt.Println()    for i:=0;i<n;i++{        insert(treeRoot,a[i])    }    inTraverse(treeRoot)    fmt.Println()}結(jié)果顯示一棵空樹。我的代碼有什么問題?Golang 有按值傳遞或按引用傳遞嗎?請幫我解決這個(gè)問題。
查看完整描述

1 回答

?
吃雞游戲

TA貢獻(xiàn)1829條經(jīng)驗(yàn) 獲得超7個(gè)贊

Go 總是按值傳遞參數(shù)。你應(yīng)該寫:


func insert(root *Node,v int) *Node {

    if root == nil{

        root = &Node{v,nil,nil}

    } else if v<root.value{

        root.left = insert(root.left,v)

    } else{

        root.right = insert(root.right,v)

    }

    return root

}

和:


for i:=0;i<n;i++{

    treeRoot = insert(treeRoot,a[i])

}

查看結(jié)果:http : //play.golang.org/p/94H_l3rfSH


查看完整回答
反對(duì) 回復(fù) 2021-11-08
  • 1 回答
  • 0 關(guān)注
  • 188 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)