数据结构树和二叉树课件.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文档。上传文档
查看更多

*由定义,二叉树的前序遍历是先访问根结点D,即第一个结点必是根;而另一方面,由于中序遍历是先左子树,其次是根,最后遍历右子树,则根结点D将中序序列分割成两部分:在D之前是左子树结点的中序序列,在D之后是右子树结点的中序序列。反过来,根据左子树的中序序列中结点个数,又可将前序序列除根以外分成左子树的前序序列和右子树的前序序列两个部分。依次类推,便可递归得到整棵二叉树。返回主目录*例如:已知结点的前序序列和中序序列分别为:前序序列:18147311223527中序序列:37111418222735则可按上述分解求得整棵二叉树。结论:给定一棵二叉树的前序序列和中序序列,可唯一确定一棵二叉树。见图p148的图6.36返回主目录*我们由此结论来推导具有n个结点的不同形态的二叉树的数目。假设对n个结点的二叉树从1到n进行编号,且令其前序序列为1,2,…n例如:下面是两棵有8个结点的二叉树它们的前序序列都而中序序列分别为(a)(b)12345678(a)12345678(b)返回主目录*所以,不同形态的二叉树的数目恰好是前序序列均为12…n的二叉树所能得到的中序序列的数目。中序遍历的过程实质上是一个结点进栈和出栈的过程。二叉树的形态确定了其结点进栈和出栈的顺序,也确定了其结点的中序序列。如图p149的图6.38所示是n=3时不同形态的二叉树在中序遍历时栈的状态和访问结点次序的关系。返回主目录*由前序序列12…n所能得到的中序序列的数目恰好为数列12…n按不同顺序进栈和出栈所能得到的排列的数目。这个数目为1C2nnC2nn-1-=n+1C2nn由二叉树的计数可推得树的计数。P149的图6.39是具有不同形态的树和二叉树。返回主目录课件部分内容来源于网络,如对内容有异议或侵权的请及时联系删除!

此课件可编辑版,请放心使用!.**3.二叉树还原为树或森林一棵二叉树还原为树或森林,具体方法为:(1)若某结点是其双亲的左孩子,则把该结点的右孩子、右孩子的右孩子、……都与该结点的双亲结点用线连起来。(2)删掉原二叉树中所有双亲结点与右孩子结点的连线。(3)整理由(1)、(2)两步所得到的树或森林,使之结构层次分明。返回主目录*一棵二叉树还原为森林的过程示意见p138图6.25:DABCEFGHIJDABCEFGHIJHIJG图6.25二叉树到森林的转换返回主目录*用递归的方法描述其转换过程为:若B是一棵二叉树,T是B的根结点,L是B的左子树,R为B的右子树,且B对应的森林F(B)中含有的n棵树为T1,T2,…,Tn,则有:(1)B为空,则F(B)为空的森林(n=0)。(2)B非空,则F(B)中第一棵树T1的根为二叉树B的根T;T1中根结点的子树森林由B的左子树L转换而成,即F(L)={T11,…,T1m};B的右子树R转换为F(B)中其余树组成的森林,即F(R)={T2,T3,…,Tn}。返回主目录*6.4.3树与森林的遍历1.树的遍历树的遍历方法主要有以下两种:1)先根遍历若树非空,则遍历方法为:(1)访问根结点。(2)从左到右,依次先根遍历根结点的每一棵子树。ABECDFGH如图中树的先根遍历序列为:ABECFHGD。返回主目录*2)后根遍历若树非空,则遍历方法为:(1)从左到右,依次后根遍历根结点的每一棵子树。(2)访问根结点。ABECDFGH如图中树的后根遍历序列为:EBHFGCDA。返回主目录*2.森林的遍历森林的遍历方法主要有以下三种:1)先序遍历若森林非空,则遍历方法为:(1)访问森林中第一棵树的根结点。(2)先序遍历第一棵树的根结点的子树森林。(3)先序遍历除去第一棵树之后剩余的树构成的森林。返回主目录*2)中序遍历若森林非空,则遍历方法为:(1)中序遍历森林中第一棵树的根结点的子树森林。(2)访问第一棵树的根结点。(3)中序遍历除去第一棵树之后剩余的树构成的森林。返回主目录*3)后序遍历若森林非空,则遍历方法为:(1)后序遍历森林中第一棵树的根结点的子树森林。(2)后序遍历除去第一棵树之后剩余的树构成的森林。(3)访问第一棵树的根结点。返回主目录*

文档评论(0)

183****1225 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档