二叉搜索树和平衡二叉树
2018-04-25 本文已影响0人
看风景的人_21744
-
二叉搜索树:树中的每一个节点x的左子树中的所有结点的值都小于x的值,右子树中所有节点的值都不小于x的值
-
插入简单,删除后的调整:
- 该节点只有1个儿子或没有儿子:直接让儿子代替它或不需要调整
- 有两个儿子:用右子树中的最小值节点替代它
-
平衡二叉树:每个节点的左子树和右子树的高度最多差1的二叉搜索树
-
平衡二叉树的构建与维护:只有1或2个节点肯定是平衡树。之后的插入可能会破坏平衡。对于辈分最小的违背平衡的节点,记作a。插入新节点之前,a是符合平衡要求的。插入后违背了平衡。
- 对a的左儿子的左子树插入
- 对a的左儿子的右子树插入
- 对a的右儿子的左子树插入
- 对a的右儿子的右子树插入
-
平衡调整:

