二叉树的实现

结构代码

typedef struct BiTNode{
    char data;//数据域 
    struct BiTNode *lchild,*rchild;//左右孩子指针 
}BiTNode,*BiTree;

1、建立二叉树 ,#表示空树

void CreateBitree(BiTree *T){

    char ch;
    //输入节点的数据 
    scanf("%c",&ch);

    //当输入的数据为#时,代表是空结点 ,没有数据 

    if(ch=='#'){
        *T=NULL;
    } else{
        //分配节点空间 
        *T=(BiTree) malloc(sizeof(BiTNode));

        if(!*T)
            exit(-1);

        (*T)->data=ch;//生成根节点

         //构造左子树 
        CreateBitree(&(*T)->lchild);
        //构造右子树 
        CreateBitree(&(*T)->rchild);
    } 
} 

为了区别是否有左右孩子,用#来区别,当输入#时,用NULL占位,表示没有左孩子或者右孩子,如图所示
这里写图片描述

2、前序遍历算法

void PreOrderTraverse(BiTree T){
    if(T==NULL)
        return;
    //显示节点数据 
    printf("%c",T->data);
    //再先序遍历左子树 
    PreOrderTraverse(T->lchild);
    //最后序遍历左子树 
    PreOrderTraverse(T->rchild);

} 

3、中序遍历算法

void InOrderTraverse(BiTree T){
    if(T==NULL)
        return;

    PreOrderTraverse(T->lchild);
    printf("%c",T->data);
    PreOrderTraverse(T->rchild);

} 

5、后序遍历算法

void PostOrderTraverse(BiTree T){
    if(T==NULL)
        return;

    PreOrderTraverse(T->lchild);
    PreOrderTraverse(T->rchild);
    printf("%c",T->data);

} 

测试代码

#include <stdio.h>
#include <malloc.h>
//函数声明
void CreateBitree(BiTree *T);
void PreOrderTraverse(BiTree T);
void InOrderTraverse(BiTree T); 
void PostOrderTraverse(BiTree T);

int main()
{
    BiTree T;
    //创建二叉树 
    CreateBitree(&T);

    //前序遍历二叉树 
    printf("前序遍历二叉树 \n");
    PreOrderTraverse(T);
    printf("\n");

    //中序遍历二叉树 
    printf("中序遍历二叉树 \n");
    InOrderTraverse(T); 
    printf("\n");

    //后序遍历二叉树 
    printf("后序遍历二叉树 \n");
    PostOrderTraverse(T);
    printf("\n");
} 

测试结构
这里写图片描述

代码下载:http://download.csdn.net/detail/a_person_alone/9489421

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值