概念:
如果一个二叉树有如下性质:
1.如果他有左子树,那么他的左子树的值都比根节点的值小。
2.如果他有右子树,那么他的右子树的节点值都比根节点的值大。
3.左子树和右子树也有同样的特性1,2.
4.理论上是没有重复值的。
代码实现:
二叉排序树的插入,查询遍历,都比较简单。但是删除极其复杂。
二叉排序树的node节点定义,data,leftnode,rightnode,parentnode。
删除一个节点分为4中情况。
1.需要删除的节点是叶子节点。
叶子节点或根节点2.需要删除的节点只有左子树。
7是父节点的左孩子,是父节点的右孩子3.需要删除的节点只有右子树。
4.需要删除的节点,左右子树都纯在。
4.1)待删除节点的右子树,没有左子树。直接将右子树替换当前的删除点
4.2
最复杂的情况,
网友评论