网站大量收购闲置独家精品文档,联系QQ:2885784924

树形结构课件.pptVIP

树形结构课件.ppt

此“教育”领域文档为创作者个人分享资料,不作为权威性指导和指引,仅供参考
  1. 1、本文档共143页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

由於bk是根結點,而在中序遍曆過程中,先遍曆左子樹,再訪問根結點,最後再遍曆右子樹。所以在中序序列中,b0b1…bk-1必是根結點bk(也就是a0)左子樹的中序序列,即bk的左子樹有k個結點(注意,k=0表示結點bk沒有左子樹。)而bk+1…bn-1必是根結點bk(也就是a0)右子樹的中序序列,即bk的右子樹有n-k-1個結點(注意,k=n-1表示結點bk沒有右子樹。)。另外,在先序序列中,緊跟在根結點a0之後的k個結點a1…ak就是左子樹的先序序列,ak+1…an-1這n-k-1就是右子樹的先序序列。根據歸納假設,由於子先序序列a1…ak和子中序序列b0b1…bk-1可以惟一地確定根結點a0的左子樹,而子先序序列ak+1…an-1和子中序序列bk+1…bn-1可以惟一地確定根結點a0的右子樹。綜上所述,這棵二叉樹的根結點己經確定,而且其左、右子樹都惟一地確定了,所以整個二叉樹也就惟一地確定了。例如,已知先序序列為ABDGCEF,中序序列為DGBAECF,則構造二叉樹的過程如下所示。根結點:A左先序:BDG左中序:DGB右先序:CEF右中序:ECF根結點:B左先序:DG左中序:DG右先序:空右中序:空根結點:D左先序:空左中序:空右先序:G右中序:G根結點:G左先序:空左中序:空右先序:空右中序:空根結點:C左先序:E左中序:E右先序:F右中序:F根結點:E左先序:空左中序:空右先序:空右中序:空根結點:F左先序:空左中序:空右先序:空右中序:空由上述定理得到以下構造二叉樹的演算法:BTNode*CreateBT1(char*pre,char*in,intn){BTNode*s;char*p;intk;if(n=0)returnNULL;s=(BTNode*)malloc(sizeof(BTNode));/*創建結點*s*/s-data=*pre;for(p=in;pin+n;p++)/*在中序中找為*ppos的位置k*/ if(*p==*pre) break;k=p-in;s-lchild=CreateBT1(pre+1,in,k); /*遞歸構造左子樹*/s-rchild=CreateBT1(pre+k+1,p+1,n-k-1);/*構造右子樹*/returns;}定理7.2:任何n(n>0)個不同結點的二又樹,都可由它的中序序列和後序序列惟一地確定。同樣採用數學歸納法證明。實際上,對於根結點ak的左右子樹,在確定左右子樹的子中序序列後,不需要確定左右子樹的整個子後序序列,只需確定子中序序列中全部字元在後序序列中最右邊的那個字元即可,因為這個字元就是子樹的根結點。例如,已知中序序列為DGBAECF,後序序列為GDBEFCA。對應的構造二叉樹的過程如下所示。根結點:A左中序:DGB左根:B右中序:ECF右根:C根結點:B左中序:DG左根:D右中序:空右根:空根結點:D左中序:空左根:空右中序:G右根:G根結點:G左中序:空左根:空右中序:空右根:空根結點:C左中序:E左根:E右中序:F右根:F根結點:E左中序:空左根:空右中序:空右根:空根結點:F左中序:空左根:空右中序:空右根:空2.中序遍曆非遞歸演算法(2)第二種方法(常規方法)由中序遍曆過程可知,採用一個棧保存需要返回的結點指針,先掃描(並非訪問)根結點的所有左結點並將它們一一進棧。然後出棧一個結點,顯然該結點沒有左孩子結點或者左孩子結點已訪問過(進一步說明該結點的左子樹均已訪問),則訪問它。然後掃描該結點的右孩子結點,將其進棧,再掃描該右孩子結點的所有左結點並一一進棧,如此這樣,直到棧空為止。voidInOrder2(BTNode*b){ BTNode*St[MaxSize],*p;inttop=-1; p=b; while(top-1||p!=NULL) {while(p!=NULL)//掃描*p的所有左結點並進棧 {top++;St[top]=p; p=p-lchild; } if(top-1)

文档评论(0)

子不语 + 关注
官方认证
服务提供商

平安喜乐网络服务,专业制作各类课件,总结,范文等文档,在能力范围内尽量做到有求必应,感谢

认证主体菏泽喜乐网络科技有限公司
IP属地未知
统一社会信用代码/组织机构代码
91371726MA7HJ4DL48

1亿VIP精品文档

相关文档