二叉树
定义
左子树节点<根节点值<右子树节点,对于二叉排序树进行中序遍历,可以得到一个递增序列,下图中序遍历序列为:1 2 3 4 6 8
二叉排序树的删除
- 若删除节点 z 是叶节点,则直接删除
- 若 z 只有一颗左子树或右子树,则让z的子树代替z的位置(用子女代替)
- 若 z 有左右子树,找第一个子女来填补
二叉树的查找效率

上图的查找效率为 ASL=(1+22+34+4*3)/10=2.9
即每层节点总数乘以所在层数求和取平均
平衡二叉树
任意节点的左右子树高度差的绝对值不超过1,这样的二叉树称为’平衡二叉树’;
左右子树的高度差称为节点的’平衡因子’
平衡二叉树的插入
下图为RR右单旋转
下图为LL左单旋转
下图为 LR先左后右 旋转
下图为 RL先右后左 旋转
哈弗曼树
树中节点常常被赋予一个表示某种意义的数值称为’权’; 树中所有叶节点的带权路径长度之和称为该树的’带权路径长度—>WPL’
带全路径计算


