文章目录
- 二叉排序树
- 总览
- 二叉排序树的定义
- 二叉排序树的查找
- 二叉排序树的插入
- 二叉排序树的构造
- 二叉排序树的删除
- 删除的是叶子节点
- 删除的是只有左子树或者只有右子树的节点
- 删除的是有左子树和右子树的节点
- 查找效率分析
- 查找成功
- 查找失败
- 小结
二叉排序树
总览
二叉排序树的定义
二叉排序树的查找
我们也可以用递归实现
但递归的最坏情况可能需要有h个函数调用栈帧,或者说h个函数同时执行
但循环的实现一直都是一个函数在执行
二叉排序树的插入
先查找找到插入的位置,然后mallloc一个新的空间,如果遇到与插入值一样的元素,则插入失败
函数参数是引用类型从而能够修改其值
二叉排序树的构造
首先T是空,会创造一个节点,其值和插入的值一样,这样就开始形成一颗树,接着插入过程和之前一样
不同序列对应的二叉排序树不一定相同,也不一定不同
二叉排序树的删除
删除的是叶子节点
直接删之后依然可以保存二叉树的特性
删除的是只有左子树或者只有右子树的节点
直接替代即可,此时依然满足,替换后,子树相对于父父树一定满足父树的相对于其父父树的性质
删除的是有左子树和右子树的节点
此时可以找到右子树的最小节点来替换(右子树的最左下节点)
此时可以找到左子树的最大节点来替换(左子树的最右下节点)
查找效率分析
查找成功
最坏的查找长度也是和这颗数的高度一样
如果使得二叉树的尽可能地平衡,那么二叉树的高度会越低
查找失败
查找失败时为落在空结点的位置,先补齐空结点