- 遇到这样一道题目,蒙住了,这一行代码为什么不可以删除temp节点呀
- 逻辑是找到root右子树最左侧节点,然后把值改了,然后删除掉这个temp
删除二叉搜索树中的节点
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 创意程序员 2023-04-04 10:00关注
从二叉树删除某个节点,不是将应该删除的这个节点设置为null,而是将该节点释放,并且修改它的父节点,将父节点的lfeft或者right指向新的节点。以题目图中为例,当找到节点3为待删除节点时,将节点3的两个子节点找出较大的那个(对于右子树,是找到较小的那个),也就是节点4,上提一层,2成为4的左子节点;3的父节点是5,它是5的左节点,将5的左节点设置为4,原3节点释放。
另外,原图中22-29这些行,可以不用这样判断,因为涉及两个子节点都不为空的情况,参考上面描述。解决 无用评论 打赏 举报
悬赏问题
- ¥15 openwrt双栈NAT
- ¥15 部分网页页面无法显示!
- ¥15 怎样解决power bi 中设置管理聚合,详细信息表和详细信息列显示灰色,而不能选择相应的内容呢?
- ¥15 QTOF MSE数据分析
- ¥15 平板录音机录音问题解决
- ¥15 请问维特智能的安卓APP在手机上存储传感器数据后,如何找到它的存储路径?
- ¥15 (SQL语句|查询结果翻了4倍)
- ¥15 Odoo17操作下面代码的模块时出现没有'读取'来访问
- ¥50 .net core 并发调用接口问题
- ¥15 网上各种方法试过了,pip还是无法使用