二叉树三种遍历的非递归算法

转载 2007年09月26日 13:19:00

本贴给出二叉树先序、中序、后序三种遍历的非递归算法,此三个算法可视为标准算法,直接用于考研答题。

1.先序遍历非递归算法
#define maxsize 100
typedef struct
{
    Bitree Elem[maxsize];
    int top;
}SqStack;

void PreOrderUnrec(Bitree t)
{
    SqStack s;
    StackInit(s);
    p=t;
   
    while (p!=null || !StackEmpty(s))
    {
        while (p!=null)             //遍历左子树
        {
            visite(p->data);
            push(s,p);
            p=p->lchild;      
        }//endwhile
        
        if (!StackEmpty(s))         //通过下一次循环中的内嵌while实现右子树遍历
        {
            p=pop(s);
            p=p->rchild;        
        }//endif
               
    }//endwhile
   
}//PreOrderUnrec

2.中序遍历非递归算法
#define maxsize 100
typedef struct
{
    Bitree Elem[maxsize];
    int top;
}SqStack;

void InOrderUnrec(Bitree t)
{
    SqStack s;
    StackInit(s);
    p=t;
    while (p!=null || !StackEmpty(s))
    {
        while (p!=null)             //遍历左子树
        {
            push(s,p);
            p=p->lchild;
        }//endwhile
        
        if (!StackEmpty(s))
        {
            p=pop(s);
            visite(p->data);        //访问根结点
            p=p->rchild;            //通过下一次循环实现右子树遍历
        }//endif   
   
    }//endwhile

}//InOrderUnrec


3.后序遍历非递归算法
#define maxsize 100
typedef enum{L,R} tagtype;
typedef struct
{
    Bitree ptr;
    tagtype tag;
}stacknode;

typedef struct
{
    stacknode Elem[maxsize];
    int top;
}SqStack;

void PostOrderUnrec(Bitree t)
{
    SqStack s;
    stacknode x;
    StackInit(s);
    p=t;
   
    do
    {
        while (p!=null)        //遍历左子树
        {
            x.ptr = p;
            x.tag = L;         //标记为左子树
            push(s,x);
            p=p->lchild;
        }
   
        while (!StackEmpty(s) && s.Elem[s.top].tag==R)  
        {
            x = pop(s);
            p = x.ptr;
            visite(p->data);   //tag为R,表示右子树访问完毕,故访问根结点      
        }
        
        if (!StackEmpty(s))
        {
            s.Elem[s.top].tag =R;     //遍历右子树
            p=s.Elem[s.top].ptr->rchild;        
        }   
    }while (!StackEmpty(s));
}//PostOrderUnrec

 

二叉树三种遍历的非递归算法

1.先序遍历非递归算法 #define maxsize 100 typedef struct { Bitree Elem[maxsize]; int top; }SqStack; v...

二叉树三种遍历的非递归算法

1.先序遍历非递归算法#define maxsize 100 typedef struct { Bitree Elem[maxsize]; int top; }SqStack; voi...

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

  • 2010年07月13日 10:15
  • 78KB
  • 下载

二叉树的先序,中序,后序遍历的非递归算法

关键是栈的运用,以此来模拟递归的过程 1.先序遍历非递归算法 #define maxsize 100 typedef struct { Bitree Elem[maxsize]; in...

二叉树的前序建立,前中后序遍历的非递归算法

二叉树的前序建立递归算法以及前中后序遍历的递归算法已经是人尽皆知了,递归算法也确实为代码的编写带来了很大的方便。然而,有时我们也确实需要它们的非递归算法。将递归算法转化为非递归算法可以帮助我们深入了解...

二叉树利用堆栈实现遍历的非递归算法

二叉树的遍历有三种不同的遍历方法,分别是前序遍历、中序遍历以及后序遍历 遍历的实现我们在上一篇博客中已经用递归的方法实现了,那么可不可以不用递归实现呢,答案是可以的,在这一篇博客中我们会利用堆栈将遍历...

二叉树的遍历(前 中 后序 )递归 非递归算法

机会是留个有准 备的人的,如果你没有得到机会,那只能说明你准备不足。      又一次的机会失掉了,好像已经错过了太多的机会,后悔也是没用的,好好总结,继续往前走吧。     这个二叉树,总是感觉...
  • Zoelov
  • Zoelov
  • 2012年10月31日 17:13
  • 828

C语言 二叉树的遍历 递归和(多种)非递归算法

//二叉树遍历 //作者:nuaazdh //时间:2011年12月1日 #include #include #define OK 1 #define ERROR...
  • nuaazdh
  • nuaazdh
  • 2012年05月31日 20:18
  • 17453
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:二叉树三种遍历的非递归算法
举报原因:
原因补充:

(最多只允许输入30个字)