二叉树删除涉及到多种情况,需要逐个处理

1.当前节点为叶子节点

  直接删除

2.当前节点右子树为空

  复制左子树中最大的值,用该值替代当前节点,删除左子树中原节点。

3.当前节点右子树不为空

  复制右子树中最小的值,用该值替代当前节点,删除右子树中原节点。

 

 

总结

  1.如果二叉树中存在大于等于或小于等于的关系,则需要根据情况选择是用右还是左,如果是严格大于小于的话左右都一样。

  2.由于替换节点时,对于被提拔的节点来说,原本的位置的处理和删除类似,因此可以将这个操作抽象出来,从而递归调用

  

 

相关文章:

  • 2022-12-23
  • 2021-07-29
  • 2022-12-23
  • 2021-05-27
  • 2021-04-12
  • 2021-10-20
  • 2021-05-27
猜你喜欢
  • 2021-12-03
  • 2022-12-23
  • 2022-12-23
  • 2021-08-21
  • 2021-06-25
  • 2021-08-19
  • 2021-08-22
相关资源
相似解决方案