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

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

二叉搜索樹的刪除功能不會刪除葉節點

二叉搜索樹的刪除功能不會刪除葉節點

元芳怎么了 2022-08-24 18:49:24
我正在Go中實現二叉搜索樹。到目前為止,我設法實現了以下功能:搜索插入按遍歷順序我唯一沒有成功實現的功能是刪除功能。當要刪除的節點是葉時,它不會被刪除。當我嘗試刪除包含值8的節點時,我期望以下輸出:{10 <nil> 0xc00009a060}{12 <nil> <nil>}{15 0xc00009a018 0xc00009a030}{18 <nil> <nil>}{20 0xc00009a078 0xc00009a090}{25 <nil> <nil>}但是,我得到以下輸出:{8 <nil> <nil>}{10 0xc00009a048 0xc00009a060}{12 <nil> <nil>}{15 0xc00009a018 0xc00009a030}{18 <nil> <nil>}{20 0xc00009a078 0xc00009a090}{25 <nil> <nil>}你可以在這里找到我的源代碼:https://play.golang.org/p/oaCYEgCt-qI
查看完整描述

1 回答

?
慕勒3428872

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

if value < tree.data {

    *parent = *tree

    tree = tree.left

} else if value > tree.data {

    *parent = *tree

    tree = tree.right

在本節中,將獲取節點的副本。稍后,您將使用哪個修改副本(而不是從樹中的上方鏈接的節點)。因此,更改為解決問題(游樂場)。請注意,您還需要考慮如果找到的節點位于樹的頂部,應該發生什么(我還沒有解決這種情況)。*parent = *treeparent.right = nil*parent = *treeparent = tree


查看完整回答
反對 回復 2022-08-24
  • 1 回答
  • 0 關注
  • 127 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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