数据结构与算法第8章 树型结构及其应用.ppt

数据结构与算法第8章 树型结构及其应用.ppt

  1. 1、本文档共124页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
8.5 哈夫曼树 * 数据结构与算法 8.5 哈夫曼树 由哈夫曼树(即由该树的HT)可得每个字符的哈夫曼编码,A、B、C、D、E、F、G、H的哈夫曼编码分别为0111、10、1110、1111、110、00、0110、010。具体实现见程序清单8-2所示。 * 数据结构与算法 8.6 小结 树型结构是一种非线性结构,它是以分支关系定义的层次结构,结构中的数据元素之间存在着“一对多”的关系,因此它为计算机应用中出现的具有层次关系或分支关系的数据,提供了一种自然的表示方法。 * 数据结构与算法 * 8.4 表达式求值问题 * 数据结构与算法 8.4 表达式求值问题 (2)后缀表达式求值 顺序扫描后缀表达式的每一项,然后根据它的类型做如下相应操作:如果是操作数,则将其压入操作数栈中;如果该项是操作符OP,则连续从操作数栈中退出两个操作数Y和X,形成运算指令YOPX,并将计算结果重新压入栈中。 * 数据结构与算法 8.4 表达式求值问题 8.4.2 算法实现 经过以上分析,利用顺序栈和二叉链表存储的二叉树,实现表达式求值问题的程序如清单8-1所示。 * 数据结构与算法 8.5 哈夫曼树 我们经常使用计算机进行一些统计工作,比如在学生每学期考试之后要按学生成绩统计优秀、良好、中等、及格和不及格的人数,以便对教学工作进行分析。 【例8-1】学生考试成绩分优秀、良好、中等、及格和不及格五个等级,请统计学生的各个分数等级上的人数。 * 数据结构与算法 8.5 哈夫曼树 * 数据结构与算法 8.5 哈夫曼树 * 数据结构与算法 8.5 哈夫曼树 哈夫曼树(Huffman)又称最优树,是一类带权路径长度最短的树。值得注意的是,最优树并不特指二叉树,但“带权路径长度最短”是在“度相同”的树中比较而得的结果,因此有最优二叉树、最优三叉树等等。最优二叉树有着广泛的应用,本节将介绍它的定义、构造方法及其具体的应用。 * 数据结构与算法 8.5 哈夫曼树 8.5.1 最优二叉树 首先给出与最优二叉树相关的术语的定义: 路径:从树中一个结点到另一个结点之间的分 支构成两个结点之间的路径。 如图8-26所示的二叉树中的B结点到D结点的路径为BC和CD两条分支构成。 * 数据结构与算法 8.5 哈夫曼树 路径长度:路径上的分支数目。 如B结点到D结点的路径长度为2。 树的路径长度:根结点到每个叶子结点的路径长度之和。如图8-26的二叉树的树的路径长度为从A到E、D、G、I四个叶子的路径长度之和,即3+3+2+3=11。 树的带权路径长度:树中所有叶子结点的带权路径长度之和。记作: * 数据结构与算法 (式8-5) 8.5 哈夫曼树 其中,n表示叶结点的数目,wi表示第i个叶结点的权值,li表示根结点到第i个叶结点之间的路径长度。 最优二叉树或哈夫曼树是n个带权叶子结点构成的所有二叉树中,带权路径长度WPL最小的二叉树。 * 数据结构与算法 8.5 哈夫曼树 【例8-2】分别求出图8-27中三棵二叉树的带权路径长度,假设它们都有4个叶子结点a、b、c、d,其权值分别为7、5、2、4。 根据上述树的带权路径长度公式可得三棵二叉树的带权路径长度分别为: WPL=7×2+5×2+2×2+4×2=36 WPL=7×3+5×3+2×1+4×2=46 WPL=7×1+5×2+2×3+4×3=35 经验证,例8-2中的图8-27(c)是在所有带权为7、5、2、4的四个叶子结点的二叉树中带权路径长度最小的二叉树,它就是哈夫曼树。 * 数据结构与算法 8.5 哈夫曼树 * 数据结构与算法 8.5 哈夫曼树 8.5.2哈夫曼树的存储表示 1. 哈夫曼树的建立 最优二叉树的构造算法是由哈夫曼提出的,所以称之为哈夫曼算法,具体描述如下: (1)根据与n个权值{w1,w2,…,wn}对应的n个结点构成n棵二叉树的森林F={T1,T2,…,Tn},其中每棵二叉树Ti(1≤i≤n)都只有一个权值为wi的根结点,其中左、右子树均为空; * 数据结构与算法 8.5 哈夫曼树 (2)在森林F中选出两棵根结点的权值最小的树生成一棵新树,而这两个根结点分别作为新树的左、右子树,且置新树的附加根结点的权值为左、右子树上根结点的权值之和; (3)从F中删除这两棵树,同时把新树加入F中; (4)重复(2)和(3),直到F中含有一棵树为止,此树便是所求的哈夫曼树。 * 数据结构与算法 8.5 哈夫曼树 【例8-3】请构造具有4个叶结点,权值分别为2,3,4,5的哈夫曼树。 构造过程如图8-28所示,图8-28(d)就是最后生成的哈夫曼树。 其带权路径长度为: WPL=2×3+3×3+4×2+5×1=26 * 数据结构与算法 8.5 哈夫曼树 * 数据结构与算法 8.5 哈夫曼树

您可能关注的文档

文档评论(0)

好文精选 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档