一、二叉排序树
这是非递归的实现
从根结点出发
删除13之后,只需要其子树替代即可
要删除的结点左右子树都有,则找其右子树中序遍历第一个被访问的结点(最左下的结点,即右子树中最小的值),替代该节点,得到结果如下:
删除的第二种方法:如下
比如查找70这个节点,需要三次对比。放在代码中,就是进行了三次循环或递归。
查找失败,表示最后指针停在null上,共有9种结果。
二、平衡二叉树
1、定义
二叉树保持平衡,其查找效率可以达到0(log n)
2、插入新节点导致的平衡二叉树不平衡的解决
①
②
③
④
⑤ why?
经过调整之后,高度恢复之前的高度,平衡因子恢复
⑥练习
⑦平衡二叉树构建
题目:用输入序列(50,40,10,30,20,35)建立一棵平衡二叉树;画出该树的构造过程。
3、查找效率分析![在这里插入图片描述](https://img-blog.csdnimg.cn/20210718102834593.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQzNjY3NTM3,size_16,color_FFFFFF,t_70)
当n=9=》最大高度为4,而当高度为5时,最少结点为12
对于平衡二叉树,给定节点数,最大高度如上
三、哈夫曼树
1、带权路径长度
以下是例子
2、哈夫曼树定义
3、哈夫曼树的构造
n棵树,需要构建n-1次
下面是另一种构建方法
首先说明一点,我们平时一般所说的哈夫曼树是指最优二叉树,也叫做严格二叉树(注意不是完全二叉树),但是哈夫曼树完全不局限于二叉树,也存在于多叉树中,即度为m的哈夫曼树,也叫最优m叉树,严格m叉树(注意不是完全m叉树).
这题表示哈夫曼树的节点 的度要么是0要么是m
设度不为0(即非叶结点 )的个数为X
则总的结点数为:X+n
除根结点外,其余的每一个结点都有一个分支连向一个结点,对于度为m的每个结点都有m个分支,而度为0的结点是没有分支的,所以从分支的情况来看
总的结点数位:X*m + 1(这里的1为根结点)
两者相等,所以答案是 (n-1) / (m-1)
3、哈夫曼编码
第二种方式可以映射成树的表示形式
第二种方式可能会造成奇异,还是哈夫曼树比较好
四、并查集
查找结点L所属的集合,并将查找路径上的所有 直接挂到A上,这样再次查找L到根节点,只需要一个路径
在进行合并之前,需要先查找到n个元素的分别的根节点,需要查找n次;合并需要n-1次。