鱼C论坛

 找回密码
 立即注册
查看: 3104|回复: 3

数据结构 二叉树遍历 求改

[复制链接]
发表于 2013-10-29 22:26:23 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include "stdio.h"
#include "conio.h"


typedef  char    DataType;
typedef struct    BitreeNode
{  
  DataType        data;
  struct    BitreeNode   *lchild;
  struct    BitreeNode  *rchild;
};
   void PreOrder(Bitree root)
   {
     if(root != NULL)
     {
       Visit( root-> data );
       PreOrder( root -> LChild );
       PreOrder( root -> RChild );
      }
    }

       void InOrder(Bitree root)
   {
     if(root != NULL)
     {
       InOrder( root -> LChild );
       Visit( root-> data );
       InOrder( root -> RChild );
      }
    }

       void PostOrder(Bitree root)
   {
     if(root != NULL)
     {
       PostOrder( root -> LChild );
       PostOrder( root -> RChild );
       Visit( root-> data );
      }
    }



BitreeNode  *CreateBitree()
{
     char  ch;
     scanf("%c",&ch);
     BitreeNode*    T=NULL;
     if(ch!='#')
     {
      T=  (struct  BitreeNode*)(malloc(sizeof(struct  BitreeNode)));
      T->data=ch;
      T->lchild=CreateBitree();
      T->rchild=CreateBitree();
       }
      return  T;
}

void    Preorder(struct  BitreeNode    *p)
{   
    if  (p!=NULL)
    {
    printf("%c",p->data);
    Preorder(  p->lchild  );
    Preorder(p->rchild  );
    }
    }

void    Postorder(struct  BitreeNode    *p)
{   
   if  (p!=NULL)
   {
    Postorder(  p->lchild  );
    Postorder(p->rchild  );
    printf("%c",p->data);
    }
}

void Inorder2(BitreeNode  *T)
{
    BitreeNode   *p;
    BitreeNode * stack[100];
    int top=0;
    stack[top++]=T;
    while (top>0)
    {
      p= stack[top-1];
      while (p)
      {
         stack[top++]= p->lchild;
         p=  stack[top-1];
       }
         p= stack[--top];
          if (top>0 )
           {
           p=stack[--top];
            cout<<p->data;
              stack[top++]= p->rchild;
             }
          }
}


void    DeleteTree(struct  BitreeNode    *p)
{   
  if  (p!=NULL)
    {
    DeleteTree(  p->lchild  );
    DeleteTree(p->rchild  );
    free(p);
    }
}
void main()
{            
     struct BitreeNode   *T=0;
     T=CreateBitree();
     printf("\nPreorder:\n");
     Preorder(T)
     printf("\nPostorder:\n");
     Postorder(T);
     printf("\nInorder2:\n");
     Inorder2(T);
     printf("\n");
     DeleteTree(T);
}


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2013-10-29 22:28:29 | 显示全部楼层
必须的顶
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-10-29 23:00:32 | 显示全部楼层
路过  学习
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-11-1 23:41:57 | 显示全部楼层
没有注释:cry哦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-17 03:30

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表