数据结构_二叉树的先序建立与先序,中序,后序(递归)遍历方式_C语言源代码

本文介绍了一种二叉树的先序建立方法,并详细解释了先序、中序和后续遍历的过程。
#include<stdio.h>
#include<stdlib.h>


typedef struct BTNode
{
        char data;
        struct BTNode * lchild;
        struct BTNode * rchild;

}BTNode;



void CreateBTree(BTNode *&T)//二叉树的先序建立
{
     char ch;
     scanf("%c",&ch);
   
     if(ch=='#')  
     {
       T=NULL;
       return;
     }
     else
     {
         T=(BTNode *)malloc(sizeof(BTNode));
         T->data=ch;
         CreateBTree(T->lchild);
         CreateBTree(T->rchild);
     }
}


void PreOrder(BTNode *T)//先序遍历
{
     if(NULL != T)
      {
             printf("%c\t",T->data);
             PreOrder(T->lchild);
             PreOrder(T->rchild);
             
      }
      
}


void InOrder(BTNode *T)//中序遍历
{
     if(NULL != T)
     {
       InOrder(T->lchild);
       printf("%c\t",T->data);
       InOrder(T->rchild);
     }
}


void PostOrder(BTNode *T)//后续遍历
{
     if(NULL != T)
     {
       PostOrder(T->lchild);
       PostOrder(T->rchild);
       printf("%c\t",T->data);
     }
     
     
}
int main(void)
{
    BTNode *T;
    CreateBTree(T);
    PreOrder(T);
    putchar(10);
    InOrder(T);
    putchar(10);
    PostOrder(T);
    putchar(10);
    system("pause");    
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值