- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
【题10】根据根据前中序遍历求后序遍历--试题解析
【题10】根据根据前、中序遍历求后序遍历
约定一棵二叉树的前序遍历和中序遍历序列,用你熟悉的程序设计语言生成该二叉树,并将其后序遍历打印出来。为便于编程,二叉树的结点用单个大写英文字母表示,且结点互不重复。比如,输入前序遍历序列为DBACPMZX,中序遍历序列为ABCDMPXZ,应生成的二叉树结构如图6.1.13所示:
图6.1.13
应输出的后序遍历序列为ACBMXZPD 注意:你的程序应能鉴别任何的错误输入。
题解
鉴别错误输入
设 predstr—前序串; s1—前序串的字符集; midstr—中序串; s2—中序串的字符集;
predstr串与midstr串必须同时满足下述三个条件方可对应同一棵二叉树:
predstr串与midstr串的长度相等;
两串的字符为 ’A’‥’Z’ 的子集且各不相同;
在predstr串中的字符必须在midstr串出现; 判别输入合法性的过程由布尔函数correct完成。若输入合法 即predstr串与midstr串可对应同一棵二叉树 ,则返回true;否则返回false。 fuction correct:boolean; begin correctfalse; if length predstr length minstr 若两序列的长度相同 then begin s1←[]; 前序串的字符集初始化 for i←1 to length predstr do 分析前序串的每一个字符 if predstr[i]s1 or predstr[i][ ’A’‥’Z’] then exit 若前序串中字符重复或出现非法字符,则返回false else s1←s1+[predstr[i]]; 否则当前字符进入前序串的字符集 s2←[]; 中序串的字符集初始化 for i←1 to length midstr do if midstr[i]s1 or midstr[i]s2 then exit 若中序串的当前字符非前序串字符或者为重复字符,则返回false else s2←s2+[midstr[i]]; 否则当前字符进入中序串的字符集 correct←true; 返回输入合法标志 end; then end; correct
构造两个线性序列对应的二叉树 若给出一棵二叉树的前序遍历和中序遍历,那么这两个线性序列可以唯一对应一棵二叉树。问题是如何由这两个线性序列推导出对应的二叉树呢?
设 predstr ’ABCD’ midstr ’BCAD’ 由前序遍历和中序遍的递归定义可以看出,前序遍历的首字符是树的根,例如上述前序序列中的’A’。我们根据该字符在中序序列中的位置i将中序序列一分为二,左端序列 即第1~i-1个字符 为左子树中序遍历的结果,例如上述中序序列中的’BC’; 右端序列 即第i+1个字符~尾字符 为右子树中序遍历的结果,例如上述中序序列中的’D’;前序序列的第2~i个字符为左子树的前序遍历的结果,例如上述前序遍历中的’BC’;前序序列的第i+1至尾部的字符为右子树前序遍历的结果。例如上述前序遍历中的’D’。这样便分别求出了左子树的根和左子树的前序序列、左子树的中序序列,右子树的根和右子树的前序序列、右子树的中序序列。再运用上述方法继续分别求解左子树和右子树。如此反复,直至对应的二叉树求出为止。显然,这一求解过程是递归的。根据上述思想,我们设计一个递归函数maketree。该函数的输入值参为前序序列和中序序列两个字串,返回的函数值为指向根结点的地址指针。 设二叉树的定义为 Type Link ↑node; node record 结点的数据类型 val:char; left,right:link; end; var root:link; function maketree predstr, midstr :link; var
root:link; 子树的根结点指针 s1,s2:string; 子树的前序串和中序串
begin
new root ; root↑.valpredstr[1]; i←pos root↑.val,midstr ;
if i 1 then root.leftnil 左子树为空
else begin s1←copy predstr,2,i-1 ; s2←copy midstr,1,i-1 ; 计算左子树的前序串和中序串 root↑.leftmaketree s1,s2 ; end; else if i length midstr then root↑.rigthnil 右子树为空 else begin s1←copy predstr,i+1,length predstr -i ; s2←copy midstr,i+1,leng
文档评论(0)