首页 > 其他分享 >第六章 树

第六章 树

时间:2022-11-11 14:36:46浏览次数:58  
标签:编码 结点 遍历 二叉树 权值 第六章 霍夫曼


一、树的定义

定义:树是n个结点的有限集。n=0时称为空树。在任意一棵非空树中:(1)有且仅有一个特定的称为根的结点;(2)当n>1时,其余结点可以分为m个互不相交的有限集T1、T2、...Tm,其中每一个集合本身又是一棵树,并且称为根的子树。

对于树的定义还需要强调两点:

1.n>0时根节点是唯一的;

2.m>0时,子树的个数没有限制,但他们一定是互不相交的。

 

结点的分类

结点拥有的子树数称为结点的度(Degree)。度为0的结点称为叶子结点(leaf),度不为0的结点称为分支结点。树的度是树内各结点的度的最大值,如图所示树的度为3。

第六章 树_数据结构

结点的子树的根称为该结点的孩子,相应的该结点称为孩子的双亲(Parent)。同一个双亲的孩子之间互称为兄弟。结点的祖先是从根到该节点所经分支上的所有结点。以某结点为根的子树中任一结点都称为该结点的子孙。

第六章 树_霍夫曼编码_02

树的层次(Level)的概念:

第六章 树_霍夫曼树_03

树中结点的最大层次称为树的深度(Depth)。

最后,对比线性表与树的结构:

第六章 树_霍夫曼编码_04

二、树的抽象数据类型

下面给出树的一些基本和常用操作:

第六章 树_数据结构_05

三、二叉树的定义

二叉树(Binary Tree)是n(n>=0)个结点的有限集合,该集合或者为空集(称为空二叉树),或者由一个根节点和两颗互不交互的、分别称为根节点的左子树和右子树的二叉树组成。

特殊二叉树:

1.满二叉树:在一棵二叉树中,如果所有的分支结点都存在左子树和右子树,并且所有叶子都在同一层上,这样的二叉树就称为满二叉树。

第六章 树_树_06

 

2.完全二叉树:对一棵具有n个结点的二叉树按层序编号,如果编号为i(1<i<n)的结点与同样深度的满二叉树中编号为i的结点在二叉树中位置完全相同,则这棵二叉树称为完全二叉树,如图:(除最后一层外,每一层上的结点数均达到最大值;在最后一层上只缺少右边的若干结点)

第六章 树_霍夫曼编码_07

所以满二叉树是完全二叉树,完全二叉树不一定是满二叉树。

 

四、二叉树的性质

性质1:在二叉树的第i层上之多有2^i-1个结点(i>=1);

性质2:深度为K的二叉树至多有2^k-1个结点(k>=1);

性质3:对于任何一棵二叉树T,如果其终端结点数为n0,度为2的结点数为n2,则n0=n2+1。

性质4:具有n个结点的完全二叉树的深度为【log2n】+1(【x】表示不大于x的最大整数)

四、二叉树的存储结构

1.二叉树的顺序存储结构:

第六章 树_数据结构_08

第六章 树_霍夫曼树_09

顺序存储一般适用于完全二叉树

2.二叉链表

二叉树每个结点最多有两个孩子,所以为它涉及一个数据域和两个指针域是比较自然的想法,我们称这样的链表叫做二叉链表。如图所示:

第六章 树_霍夫曼树_10

二叉链表的结点结构定义代码如下:

第六章 树_数据结构_11

结构示意图如下:

第六章 树_霍夫曼树_12

五、遍历二叉树

二叉树的遍历是指从根节点出发,按照某种次序依次访问二叉树中的所有结点,使得每个结点被访问一次,且仅被访问一次。

二叉树的遍历方法

1.前序遍历:规则是若二叉树为空,则空操作返回,否则先访问根节点,然后前序遍历左子树,再前序遍历右子树。如图所示:(根左右)

第六章 树_数据结构_13

 

2.中序遍历:(左根右)

第六章 树_树_14

3.后序遍历(左右根)

第六章 树_结点_15

4.层序遍历:

第六章 树_数据结构_16

下面来看一下前序遍历算法

二叉树的定义是用递归的方式,所以,实现遍历算法也可以采用递归,而且极其简洁明了:

 

第六章 树_数据结构_17

中序遍历算法:

第六章 树_结点_18

后序遍历算法:

第六章 树_霍夫曼树_19

六、二叉树的建立

为了能让每个结点确认是否有左右孩子,我们对它进行了扩展,如图:

第六章 树_霍夫曼树_20

扩展二叉树就可以做到一个遍历序列确定一个二叉树了,上图的前序遍历序列就是AB#D##C##。有了这样的准备,我们就可以来看看如何生成一棵二叉树了。实现算法如下:

第六章 树_树_21

第六章 树_数据结构_22

七、霍夫曼树及其应用

最基本的压缩编码方法-霍夫曼编码,在介绍霍夫曼编码前,我们必须得介绍霍夫曼树,而介绍霍夫曼树。带权路径长度WPL最小的二叉树称作霍夫曼树。也有不少树中称为最优二叉树。

第六章 树_霍夫曼树_23

二叉树a的WPL=315,二叉树b的WPL=220。

下面介绍一下霍夫曼树的构造:

一、对给定的n个权值{W1,W2,W3,...,Wi,...,Wn}构成n棵二叉树的初始集合F= {T1,T2,T3,...,Ti,...,Tn},其中每棵二叉树Ti中只有一个权值为Wi的根结点,它的左右子树均为空。(为方便在计算机上实现算 法,一般还要求以Ti的权值Wi的升序排列。)
二、在F中选取两棵根结点权值最小的树作为新构造的二叉树的左右子树,新二叉树的根结点的权值为其左右子树的根结点的权值之和。
三、从F中删除这两棵树,并把这棵新的二叉树同样以升序排列加入到集合F中。
四、重复二和三两步,直到集合F中只有一棵二叉树为止。

简易的理解就是,假如我有A,B,C,D,E五个字符,出现的频率(即权值)分别为5,4,3,2,1,那么我们第一步先取两个最小权值作为左右子树构造一个新树,即取1,2构成新树,其结点为1+2=3,如图:

​​第六章 树_数据结构_24​​

虚线为新生成的结点,第二步再把新生成的权值为3的结点放到剩下的集合中,所以集合变成{5,4,3,3},再根据第二步,取最小的两个权值构成新树,如图:

​​第六章 树_数据结构_25​​

再依次建立哈夫曼树,如下图:

​​第六章 树_霍夫曼编码_26​​

其中各个权值替换对应的字符即为下图:

​​第六章 树_数据结构_27​​

所以各字符对应的编码为:A->11,B->10,C->00,D->011,E->010

 

下面研究一下霍夫曼编码:

一般地,设需要编码的字符集为{d1,d2,......dn},各字符在电文中出现的次数或频率的集合为{w1,w2,......wn},以d1,d2,......dn作为叶子结点,以w1,w2,......wn作为相应叶子结点的权值来构造一棵霍夫曼树。规定霍夫曼树的左分支代表0,右分支代表1,则从根节点到叶子结点所经过的路径分支组成的0和1的序列便为该结点对应字符编码,这就是霍夫曼编码。

例子:我们在发送电报的时候用到了六个字母,其出现的概率分别为:A 27,B 8,C 15, D 15,E 30,F 5,合起来正好是百分之百。

怎么获得霍夫曼编码呢?

首先按照比率作为权值画霍夫曼树,然后将左分支代表0,右分支代表1,如图:

第六章 树_数据结构_28

从根节点到叶子结点所经过的路径分支组成的0和1的序列便为该结点对应字符编码,即:

第六章 树_树_29

 

这样就获得了霍夫曼编码。

标签:编码,结点,遍历,二叉树,权值,第六章,霍夫曼
From: https://blog.51cto.com/u_15866446/5844840

相关文章

  • 第六章15
    【题目描述】你知道吗?在外国,如果你不修剪你的花圃,是要被贴罚单的。Xman忙于战斗,被贴了好多罚单。这一次好不容易休息了,他决定修剪一下。修剪成什么样子呢?当然是X形。Xman......
  • 第六章11
    【题目描述】有一个m行n列的矩阵,编程求出其中值最大的那个元素,以及其所在的行号和列号。(如果最大数有多个,则显示第一个出现的数据的信息)。【输入】有多行。第1行是两个......
  • 第六章12
    【题目描述】编写一个程序,求出n×m的二维数组周边元素之和。【输入】有多行。第1行是两个整数n(≤10)和m(≤10),分别表示二维数组共n行m列元素。接下来是n行m列的二维数组元......
  • 第六章13
    【题目描述】大一第一学期的期中考试结束了,辅导员急切的想了解同学们的学习情况,现在请你帮忙编程计算出每位学生的总分和每门课程的平均分,以便帮助他快速统计出同学们的课......
  • 第六章14
    【题目描述】在微分方程中,沿着某一方向是稳定的,另一条方向是不稳定的奇点,叫做鞍点。在泛函中,既不是极大值点也不是极小值点的临界点,叫做鞍点。在矩阵中,一个数在所在行中是......
  • 第六章10
    【题目描述】2015年股市以爆发性行情揭开了新一轮牛市的序幕,小明同学趁着手里有点小钱,想要购买CFun公司的股票,但CFun公司的股票价格是不稳定的,并且购买股票后只能在第三天......
  • 第六章9
    【题目描述】LittleBoblikesplayingwithhisboxofbricks.Heputsthebricksoneuponanotherandbuildsstacksofdifferentheight.''Look,I'vebuiltaw......
  • 第六章8
    【题目描述】校园歌手大奖赛中,评委会给参赛选手打分(0~100分)。选手得分规则为去掉一个最高分和一个最低分,然后计算平均得分,请编程输出某选手的得分。【输入】有两行。第1......
  • 第六章7
    【题目描述】一年一度的校园歌手大奖赛开赛啦!!!跟往年一样得到了大家的踊跃响应,报名人数巨多,按惯例还是要先进行分组预赛。按规定,每10名学生为一个预赛小组,评委打出分数(0~10......
  • 第六章 字典
    6.1使用字典字典使一系列键-值对每个键都与一个值相关联,使用键来访问与之相关联的值键:数字、字符串值:数字、字符串、列表、字典alien_0={'color':'green','points'......