- 1、本文档共124页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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 哈夫曼树
您可能关注的文档
- 第2章《高频电子线路》_(曾兴雯)_版高等教育出版社课后答案文库.ppt
- 第4章《高频电子线路》_(曾兴雯)_版高等教育出版社课后答案文库.ppt
- 坚定加强民族团结维护社会稳定和谐[1].ppt
- [高等教育]第四章员工招聘课件.ppt
- 气相色谱分析法 仪器分析普通高等教育课程电子教案.ppt
- Python概述 Python介绍.ppt
- cisp0304重要信息安全管理过程.ppt
- [高等教育]怎样度过大学生活.ppt
- [高等教育]3第三章 法规与规章性文书写作.ppt
- 2018届高考政治时政速递:聚焦“新四大发明” 打造“中国智造”新名片.pptx
- 第12课 大一统王朝的巩固 课件(20张ppt).pptx
- 第17课 君主立宪制的英国 课件.pptx
- 第6课 戊戌变法 课件(22张ppt).pptx
- 第三章 物态变化 第2节_熔化和凝固_课件 (共46张ppt) 人教版(2024) 八年级上册.pptx
- 第三章 物态变化 第5节_跨学科实践:探索厨房中的物态变化问题_课件 (共28张ppt) 人教版(2024) 八年级上册.pptx
- 2025年山东省中考英语一轮复习外研版九年级上册.教材核心考点精讲精练(61页,含答案).docx
- 2025年山东省中考英语一轮复习(鲁教版)教材核心讲练六年级上册(24页,含答案).docx
- 第12课近代战争与西方文化的扩张 课件(共48张ppt)1.pptx
- 第11课 西汉建立和“文景之治” 课件(共17张ppt)1.pptx
- 唱歌 跳绳课件(共15张ppt内嵌音频)人音版(简谱)(2024)音乐一年级上册第三单元 快乐的一天1.pptx
最近下载
- 肝囊肿开窗引流术后护理查房.pptx
- 芯源微 -国内涂胶显影设备龙头, 国内涂胶显影设备龙头, 国内涂胶显影设备龙头, 布局化学清洗和 布局化学清洗和先进封装 先进封装 20240625 -西部证券.docx
- 2023-2024年EMS审核知识统考试题及答案汇总.pdf VIP
- 一种标示牌粘贴工具.pdf VIP
- DBJ50_T-157-2022 房屋建筑和市政基础设施工程施工现场从业人员配备标准.docx
- 云南省保山市隆阳区金厂河铜锌铁多金属矿矿床水文地质特征.doc VIP
- 电化学阻抗谱(EIS)原理及谱图分析.pptx
- 中班-科学-前进!磁力车(磁铁同极相斥、异极相吸)-课件(互动版).pptx
- 柳永《八声甘州》优质课件.ppt
- 道德与法治五年级上册第四单元传统美德 源远流长 教学设计.pdf
文档评论(0)