欢迎来到入门教程网!

C语言

当前位置:主页 > 软件编程 > C语言 >

二叉树前序遍历的非递归算法

来源:本站原创|时间:2020-01-10|栏目:C语言|点击:

二叉树的前序遍历是先根节点,然后如果有左子树则再先序遍历左子树,然后如果有右子树则再先序遍历其又子树。
递归算法如下

复制代码 代码如下:

 void   preorder(Betree *t)
{   if(t==null) return;visit(t);//访问该节点preorder(t->lchild);preorder(t->rchild); }

当然递归算法是隐式使用了栈。我们仔细分析这个过程,先是取出了根节点进行了访问,然后我们把根节点退栈,退栈后必然有节点进栈,怎么办呢?根节点只能直接访问到rchild和lchild,如果是左子树的根节点进了栈,那么必然是后访问之,所以必然是rchild先进栈,lchild后进栈。可以画图加深理解。
那么现在写出先序遍历二叉树的算法。
复制代码 代码如下:

void preorder(Betree *t)
{ //算法中我们使用一维数组来模拟一个顺序栈
     if(t==null) return;//为空树的话完全没有必要进行下面的操作    
     Betree *stack[max];
     top=1;stack[top]=t;//根节点入栈
     while(top>0)
    {   nd=stack[top];//取出根节点  top=top-1;//退栈   visit(nd->data); //访问根节点 if(nd->rchild!=null) { top=top+1;stack[top]=nd->rchild;} //根节点有右子树,将其进栈,等到左子树访问完后再访问之
if(nd->lchild!=null) { top=top+1;stack[top]=nd->lchild;}
   }
}

上一篇:tcp socket客户端和服务端示例分享

栏    目:C语言

下一篇:数据结构顺序表操作示例

本文标题:二叉树前序遍历的非递归算法

本文地址:https://www.xiuzhanwang.com/a1/Cyuyan/3754.html

网页制作CMS教程网络编程软件编程脚本语言数据库服务器

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:835971066 | 邮箱:835971066#qq.com(#换成@)

Copyright © 2002-2020 脚本教程网 版权所有