5.5树与二叉树的应用

一、二叉排序树

在这里插入图片描述
在这里插入图片描述
这是非递归的实现
在这里插入图片描述
在这里插入图片描述
从根结点出发

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
删除13之后,只需要其子树替代即可
在这里插入图片描述
要删除的结点左右子树都有,则找其右子树中序遍历第一个被访问的结点(最左下的结点,即右子树中最小的值),替代该节点,得到结果如下:
在这里插入图片描述
删除的第二种方法:如下
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
比如查找70这个节点,需要三次对比。放在代码中,就是进行了三次循环或递归。
在这里插入图片描述
在这里插入图片描述
查找失败,表示最后指针停在null上,共有9种结果。
在这里插入图片描述

二、平衡二叉树

1、定义

在这里插入图片描述
二叉树保持平衡,其查找效率可以达到0(log n)

2、插入新节点导致的平衡二叉树不平衡的解决

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

⑤ why?

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
经过调整之后,高度恢复之前的高度,平衡因子恢复

⑥练习

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

⑦平衡二叉树构建

题目:用输入序列(50,40,10,30,20,35)建立一棵平衡二叉树;画出该树的构造过程。
在这里插入图片描述

3、查找效率分析在这里插入图片描述

在这里插入图片描述
当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次。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值