- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[2018年最新整理]二叉树遍历的非递归实现
二叉树遍历的非递归实现
前面给出的二叉树先序、中序和后序三种遍历算法都是递归算法。当给出二叉树的链式存储结构以后,用具有递归功能的程序设计语言很方便就能实现上述算法。然而,并非所有程序设计语言都允许递归;另一方面,递归程序虽然简洁,但可读性一般不好,执行效率也不高。因此,就存在如何把一个递归算法转化为非递归算法的问题。解决这个问题的方法可以通过对三种遍历方法的实质过程的分析得到。
如图6.3(b)所示的二叉树,对其进行先序、中序和后序遍历都是从根结点A开始的,且在遍历过程中经过结点的路线是一样的,只是访问的时机不同而已。图6.9中所示的从根结点左外侧开始,由根结点右外侧结束的曲线,为遍历图6.3(b)的路线。沿着该路线按△标记的结点读得的序列为先序序列,按*标记读得的序列为中序序列,按⊕标记读得的序列为后序序列。
然而,这一路线正是从根结点开始沿左子树深入下去,当深入到最左端,无法再深入下去时,则返回,再逐一进入刚才深入时遇到结点的右子树,再进行如此的深入和返回,直到最后从根结点的右子树返回到根结点为止。先序遍历是在深入时遇到结点就访问,中序遍历是在从左子树返回时遇到结点访问,后序遍历是在从右子树返回时遇到结点访问。
图6.9 遍历图6.3(b)的路线示意图
在这一过程中,返回结点的顺序与深入结点的顺序相反,即后深入先返回,正好符合栈结构后进先出的特点。因此,可以用栈来帮助实现这一遍历路线。其过程如下。
在沿左子树深入时,深入一个结点入栈一个结点,若为先序遍历,则在入栈之前访问之;当沿左分支深入不下去时,则返回,即从堆栈中弹出前面压入的结点,若为中序遍历,则此时访问该结点,然后从该结点的右子树继续深入;若为后序遍历,则将此结点再次入栈,然后从该结点的右子树继续深入,与前面类同,仍为深入一个结点入栈一个结点,深入不下去再返回,直到第二次从栈里弹出该结点,才访问之。
(1)先序遍历的非递归实现
在下面算法中,二叉树以二叉链表存放,一维数组stack[MAXNODE]用以实现栈,变量top用来表示当前栈顶的位置。
void NRPreOrder(BiTree bt)
{/*非递归先序遍历二叉树*/
BiTree stack[MAXNODE],p;
int top;
if (bt==NULL) return;
top=0;
p=bt;
while(!(p==NULLtop==0))
{ while(p!=NULL)
{ Visite(p-data); /*访问结点的数据域*/
if (topMAXNODE-1) /*将当前指针p压栈*/
{ stack[top]=p;
top++;
}
else { printf(“栈溢出”);
return;
}
p=p-lchild; /*指针指向p的左孩子*/
}
if (top=0) return; /*栈空时结束*/
else{ top--;
p=stack[top]; /*从栈中弹出栈顶元素*/
Visite(p-data); /*访问结点的数据域*/
p=p-rchild; /*指针指向p的右孩子结点*/
}
}
}
算法 6.9
对于图6.3(b)所示的二叉树,用该算法进行遍历过程中,栈stack和当前指针p的变化情况以及树中各结点的访问次序如表6.1所示。
表6.1 二叉树先序非递归遍历过程
步骤 指针p 栈stack内容 访问结点值 初态 A 空 1 B A A 2 D A,B B 3 ∧ A,B,D D 4 G A,B 5 ∧ A,B,G G 6 ∧ A,B 7 ∧ A 8 C 空 9 E C C 10 ∧ C,E E 11 ∧ C 12 F 空 13 ∧ F F 14 ∧ 空
(2)中序遍历的非递归实现
中序遍历的非递归算法的实现,只需将先序遍历的非递归算法中的Visite(p-data)移到p=stack[top]和p=p-rchild之间即可。
(3)后序遍
您可能关注的文档
最近下载
- 一种智能管理试剂的装置及方法.pdf VIP
- 北京工业大学2023-2024学年第1学期《高等数学(上)》期末考试试卷(B卷)附参考答案.pdf
- Cinema 4D动画实战项目教程:C4D角色动画PPT教学课件.pptx VIP
- GB_T_1690-2010硫化橡胶或热塑性橡胶耐液体试验方法.docx VIP
- 特种设备作业人员监督管理办法.pptx VIP
- Cinema 4D动画实战项目教程:C4D建模技法PPT教学课件.pptx VIP
- 农田土壤健康评价技术规程.pdf VIP
- 浸没式光刻技术.pdf VIP
- 浸没式光刻技术课件.ppt VIP
- 2025年湖南省娄底市中考英语试卷真题(含答案解析).docx
文档评论(0)