- 1、本文档共143页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)
您可能关注的文档
- 生殖系统与乳腺疾病课件.ppt
- 声卡基础知识课件.ppt
- 声频系统课件.ppt
- 施工定额课件.ppt
- 施工方案课件.ppt
- 施工排水课件.ppt
- 施工图预算的编制课件.ppt
- 施工现场的电力供应课件.ppt
- 施工现场供配电课件.ppt
- 施工现场临时用电若干规定课件.ppt
- 法律法规培训计划与实施方案(五).docx
- 死亡诉讼申请书范本(3).docx
- 老公在侧儿子在旁得文案.docx
- Unit 5 Work time Lesson1 课件(共32张PPT)(2025年新版).pptx
- A Let's learn&Let's do(2025年新版的啊啊).ppt
- Unit 2 I think that mooncakes are delicious! Section B 2a—Self Check 课件 (共22张PPT)人教版九年级全一册36.pptx
- Unit 5 Education Lesson 1课件(共17张ppt) 北师大版英语选择性必修第二册.ppt
- Unit 4 Looking good, feeling good Extended reading课件(共16张PPT,内镶嵌视频和音频) 2024-2025学年高一英语牛津译林版(2019)必修.pptx
- Unit 3 Learning better Part B Let's talk — Play a guessing game 课件(共22张PPT)(2025年新版).pptx
- Unit 2 Clean our classroom第三课时 Wrap-up time Making a cleaning plan课件(共20张PPT).pptx
最近下载
- lng接收站工艺培训计划.docx VIP
- 五懂五会五能员工必备安全技能手册.pdf
- 化妆品行业化妆品生产厂复工安全培训.pptx
- 2024年10月13日云南省税务系统遴选笔试真题及答案解析.doc VIP
- 2023年中考数学几何模型——动点最值之瓜豆模型(讲+练)(原卷版).pdf VIP
- (新统编版)语文四年级下册 第一单元集体备课指导 课件.pptx
- 四川省2023-2024学年 职教高考联合体第4次模拟考试-智能制造类应知+应会(含答案).pdf VIP
- 1危险化学品磷酸(正磷酸)的危险、有害特性表MSDS.docx
- 2《陈涉世家》精省公开课一等奖全国示范课微课金奖PPT课件.pptx
- 攀枝花学院2020-2021学年第1学期《高等数学(上)》期末考试试卷(A卷)及标准答案.pdf
文档评论(0)