第六章二叉树和树.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构的内容 第6章 树 第6章 树 6.1 二叉树 为何要先研究每结点最多只有两个 “叉” 的树? 二叉树的结构最简单,规律性最强; 可以证明,所有树都能转为唯一对应的二叉树,不失一般性。 6.1.1 二叉树(Binary Tree)的定义和基本术语 2. 基本术语 2. 基本术语(续) 课堂练习: 课堂讨论: 6.1.3. 二叉树的存储结构 讨论:不是完全二叉树怎么办? 2、链式存储结构 用二叉链表即可方便表示。 例: 6.2 二叉树遍历 例1: 例2:用二叉树表示算术表达式 一、编历递归算法 先序遍历算法 prev( NODE *root ) {if (root !=NULL) //非空二叉树 {printf(“%d”,root-data); //访问D prev(root-lchild); //递归遍历左子树 prev(root-rchild); //递归遍历右子树 } return(0); } 对遍历的分析: 特别讨论:若已知先序/后序遍历结果和中序遍历结果,能否“恢复”出二叉树? 【严题集6.31④】 证明:由一棵二叉树的先序序列和中序序列可唯一确定这棵二叉树。 中序遍历:B D C E A F H G 后序遍历:D E C B H G F A 二叉树小结: 6.3 树和森林 1. 树的定义 2. 森林的定义 3. 树的基本操作 要明确: 1. 普通树(即多叉树)若不转化为二叉树,则运算很难实现。 2. 二叉树的运算仍然是插入、删除、修改、查找、排序等,但这些操作必须建立在对树结点能够“遍历”的基础上! (遍历——指每个结点都被访问且仅访问一次,不遗漏不重复)。 6.3.2 树和森林的存储结构 例1: 双亲表示法 2、孩子表示法 将双亲表示法与孩子表示法结合,就成了树的双亲孩子表示法: 3、孩子兄弟表示法 例如: 补充1:树与二叉树的转换 树转二叉树举例: 讨论2:二叉树怎样还原为树? 补充2:森林与二叉树的转换 森林转二叉树举例:(法二) 讨论2:二叉树如何还原为森林? 6.4 树的应用 Huffman树简介: 构造霍夫曼树的基本思想: 构造Huffman树的步骤: 操作要点2:按左0右1对Huffman树的所有分支编号! 例2(严题集6.26③):假设用于通信的电文仅由8个字母 {a, b, c, d, e, f, g, h} 构成,它们在电文中出现的概率分别为{ 0.07, 0.19, 0.02, 0.06, 0.32, 0.03, 0.21, 0.10},试为这8个字母设计哈夫曼编码。如果用0~7的二进制编码方案又如何? 为清晰起见,重新排序为: w={2, 3, 6, 7, 10, 19, 21, 32} 对应的哈夫曼编码(左0右1): 例3:设字符集为26个英文字母,其出现频度如下表所示。 二叉树小结 注1:过去许多书籍中都定义树为n≥1,曾经有“空树不是树”的说法,但现在树的定义已修改。 注2:树的定义具有递归性,即树中还有树。 由一个或多个(n≥0)结点组成的有限集合T,有且仅有一个结点称为根(root),当n1时,其余的结点分为m(m≥0)个互不相交的有限集合T1,T2,…,Tm。每个集合本身又是棵树,被称作这个根的子树 。 6.3.1 树和森林的定义 A B C G E I D H F J K 森林是m(m≥0)棵不相交的树的集合。 6.3.1 树和森林的定义 因此也可将树定义成:是n(n≥0)个结点组成的有限集合T,若n=0,则是空树;否则,树由一个根结点和m(m≥0)棵树组成的森林构成,森林中的每棵树都是根的子树 。 B C G E I D H F J K 森林: A B C G E I D H F J K 树: 树有三种常用存储方式: ①双亲表示法 ②孩子表示法 ③孩子兄弟表示法 1、用双亲表示法来存储 思路:用一组连续空间来存储树的结点,同时在每个结点中附设一个指示器,指示其双亲结点在链表中的位置。 parents data 结点结构 data parents 1 树结构 2 3 n A B C G E I D H F 缺点:求结点的孩子时需要遍历整个结构。 data parent A 0 B 1 C 1 D 9 E 2 F 2 G 3 H 5 I 5 5 下标 1 2 3 0 4 5 6 7 8 9 思路:将每个结点的孩子排列起来,形成一个带表头(装父结点)的线性表(n个结点要设立n个链表); 再将n个表头用数组存放起来,这样就形成一个混合结构。 A B C G E I D H F data link A B C D ^

文档评论(0)

wuyoujun92 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档