- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构与算法Java版罗文劼第4章树结构课件教学.ppt
PPT研究院 POWERPOINT ACADEMY * * * 4.6 最优二叉树 4.6.1问题的引入 一个将百分制转换为五级分制的判定程序可以用以下条件语句完成: if (a60) b=”bad”; else if (a70) b=”pass” else if (a80) b=”general” else if (a90) b=”good” else b=”excellent”; 判定过程如下图所示。 * 判定方法是多样的,也可以采用下面的判定过程来完成。 * 在给定一组具有确定权值的叶结点,可以构造出不同的带权二叉树。 下图中的每棵二叉树都有4个结点,且权值相同,但其带权路径长度不同,分别为: (a)WPL=1×2+3×2+5×2+7×2=32 (b)WPL=1×3+3×3+5×2+7×1=29 (c)WPL=1×2+3×3+5×3+7×1=33 (d)WPL=7×3+5×3+3×2+1×1=43 (e)WPL=7×1+5×2+3×3+1×3=29 * 3.哈夫曼(Haffman)树: 哈夫曼树也称最优二叉树。由上面的例子可见,由相同权值的一组叶子结点所构成的二叉树可能有不同的形态和不同的带权路径长度,具有最小带权路径长度的二叉树称为哈夫曼(Haffman)树,也称最优二叉树。 最优二叉树在实际问题中有很重要的应用。 * 下图给出前面提到的叶结点权值集合为W={1,3,5,7}的哈夫曼树的构造过程。可以计算出其带权路径长度为29。 * 2、算法实现 * 4.6.3 最优二叉树的应用--哈夫曼编码 * 4.7 树 4.7.1树的基本操作 树的基本操作通常有以下几种: Initiate(t) Root(x) Parent(t,x) Child(t,x,i) RightSibling(t,x) Insert(t,x,i,s) Delete(t,x, i) Tranverse(t) * 4.7.2 树的表示 1.直观表示法 * 2.嵌套集合表示法 * 3.凹入表示法 4.广义表表示法 (A(B(D,E(H,I),F),C(G))) * 4.7.3 树的存储 1.双亲链表存储方法 * 2.指向孩子的链表存储方法 ⑴多重链表法 令每个结点包括一个结点信息域和多个指针域,每个指针域指向该结点的一个孩子结点,通过各个指针域值反映出树中各结点之间的逻辑关系。在这种表示法中,树中每个结点有多个指针域,形成了多条链表,所以这种方法又常称为多重链表法。 * ⑵孩子链表表示法 * 3.双亲孩子链表存储方法 * 4.孩子兄弟链表存储方法 从树的孩子兄弟表示法可以看到,如果设定一定规则,就可用二叉树结构表示树和森林,这样,对树的操作实现就可以借助二叉树存储,利用二叉树上的操作来实现。 * 4.7.4 树和森林与二叉树之间的转换 1. 树转换为二叉树 * 下图给出森林及其转换为二叉树的过程。 2. 森林转换为二叉树 * 下图给出一棵二叉树还原为森林的过程示意。 3. 二叉树转换为树和森林 * 1. 树的遍历 (1)先序遍历 按照树的先根遍历的定义,对上图所示的树进行先根遍历,得到的结果序列为:A B E F C D G 4.7.5 树或森林的遍历 * 2.后序遍历 按照树的后序遍历的定义,对下图所示的树进行后根遍历,得到的结果序列为: E F B C G D A * 2. 森林的遍历 (1)先序遍历 对于下图所示的森林进行前序遍历,得到的结果序列为: A B C D E F G H J I K * (2)后序遍历 对于下图所示的森林进行中序遍历,得到的结果序列为: B A D E F C J H K I G * 4.7.6 树的应用 1、集合的表示 * 2.集合的运算 馋死 * 1.先序遍历 先序遍历的递归过程为:若二叉树为空,遍历结束。否则, (1) 访问根结点; (2) 先序遍历根结点的左子树; (3) 先序遍历根结点的右子树。 * 对于上图所示的二叉树,按先序遍历所得到的结点序列为: A B D G C E F * 2.中序遍历 中序遍历的递归过程为:若二叉树为空,遍历结束。否则, (
您可能关注的文档
最近下载
- 阿里斯顿VL70VH3.0EVOAG+WH说明书.pdf
- GB50154-2009地下及覆土火药炸药仓库设计安全规范.docx VIP
- 软质岩岩土工程勘察技术标准DB62_T 3285-2024.docx VIP
- 《JJG1006-2005-煤中全硫测定仪检定规程》.pdf
- 华中师范大学841有机化学2018年考研真题.pdf VIP
- 高质量数据集 建设指南.pdf
- 新12J07室外工程-标准图集.docx VIP
- 基于PLC的全自动洗衣机控制系统设计.docx VIP
- KDOQI血液透析充分性临床实践指南2015更新版-开始血液透析的时机解读.pdf VIP
- T CALC 09—2025 免陪照护服务基本规范.pdf VIP
原创力文档


文档评论(0)