→ longlongint: 先看抽象概念 刪除 node 後要找一個 node 來頂位置12/14 19:20
→ longlongint: 這個 node key 要比左邊全部大 比右邊全部小,自然12/14 19:20
→ longlongint: 是挑右子樹的最小值來用囉12/14 19:20
※ 編輯: sdfg014025xx (180.217.169.134), 12/14/2017 19:26:31
→ sdfg014025xx: 概念上大概了解...可是程式的實作有點看不懂 12/14 19:28
→ galic: 因為程式碼錯了.. 12/14 20:24
→ sdfg014025xx: 真的嗎?這是老師出作業挖空給我們寫的 12/14 20:39
→ galic: 因為課本寫錯了 老師傻傻相信 慘 12/14 21:53
→ sdfg014025xx: 可是照這樣的程式碼跑一些測資還是對的,可以請教一 12/14 22:08
→ sdfg014025xx: 下他錯在哪嗎QQ 這邊卡住很久 12/14 22:08
→ galic: 第三.Deleting a node with two children... 12/14 22:15
→ galic: D就是你要刪的點 E是找到in-order順序大一位要來替代的點 12/14 22:15
→ galic: E可能有right sub-tree F 12/14 22:16
→ galic: 用E的值覆蓋D E沒有右子就刪除node 但E可能有右子F 12/14 22:17
→ galic: 這時候應該是要F去替換E 而不是把F變成D的右子 12/14 22:18
→ galic: 那D原本的右子去哪了? 12/14 22:18
推 peterwu4: 其實不複雜,換完值後,要刪除的點就是葉子或是一個子 12/14 22:44
→ peterwu4: node的點,利用recursive的概念,把那個點再餵回去就可 12/14 22:46
→ peterwu4: 以處理掉 12/14 22:46
推 nova06091: 老師居然沒自己打過 ... 12/15 09:15
→ sdfg014025xx: 感謝各位! 12/15 13:11
推 longlongint: 我也忘了補位要遞迴 感謝p大 12/15 21:25
推 peterwu4: ^^" 12/16 16:20