peach2580 2023-04-04 09:18 采纳率: 80%
浏览 23

删除二叉搜索树中的节点

  • 遇到这样一道题目,蒙住了,这一行代码为什么不可以删除temp节点呀
  • 逻辑是找到root右子树最左侧节点,然后把值改了,然后删除掉这个temp

img

  • 写回答

2条回答 默认 最新

  • 创意程序员 2023-04-04 10:00
    关注

    从二叉树删除某个节点,不是将应该删除的这个节点设置为null,而是将该节点释放,并且修改它的父节点,将父节点的lfeft或者right指向新的节点。以题目图中为例,当找到节点3为待删除节点时,将节点3的两个子节点找出较大的那个(对于右子树,是找到较小的那个),也就是节点4,上提一层,2成为4的左子节点;3的父节点是5,它是5的左节点,将5的左节点设置为4,原3节点释放。
    另外,原图中22-29这些行,可以不用这样判断,因为涉及两个子节点都不为空的情况,参考上面描述。

    评论

报告相同问题?

问题事件

  • 创建了问题 4月4日

悬赏问题

  • ¥15 openwrt双栈NAT
  • ¥15 部分网页页面无法显示!
  • ¥15 怎样解决power bi 中设置管理聚合,详细信息表和详细信息列显示灰色,而不能选择相应的内容呢?
  • ¥15 QTOF MSE数据分析
  • ¥15 平板录音机录音问题解决
  • ¥15 请问维特智能的安卓APP在手机上存储传感器数据后,如何找到它的存储路径?
  • ¥15 (SQL语句|查询结果翻了4倍)
  • ¥15 Odoo17操作下面代码的模块时出现没有'读取'来访问
  • ¥50 .net core 并发调用接口问题
  • ¥15 网上各种方法试过了,pip还是无法使用