数据结构//C——静态——链式二叉树(递归)

# include <stdio.h>
# include <malloc.h>

typedef  struct TNode{
    char data;
    struct TNode * pL_child;
    struct TNode * pR_child;
} NODE, * pNODE;

struct TNode * Create_tree();
void Pre_traverse(pNODE);
void IN_traverse(pNODE);
void Post_traverse(pNODE);

int main (void){

    pNODE pNode = Create_tree();

    Pre_traverse(pNode);
    printf("\n");

    IN_traverse(pNode);
    printf("\n");

    Post_traverse(pNode);

    return 0;
}
struct TNode * Create_tree(){
    pNODE pA = (pNODE) malloc(sizeof(NODE));
    pNODE pB = (pNODE) malloc(sizeof(NODE));
    pNODE pC = (pNODE) malloc(sizeof(NODE));
    pNODE pD = (pNODE) malloc(sizeof(NODE));
    pNODE pE = (pNODE) malloc(sizeof(NODE));

    pA->data = 'A';
    pB->data = 'B';
    pC->data = 'C';
    pD->data = 'D';
    pE->data = 'E';

    pA->pL_child = pB;
    pA->pR_child = pC;
    pB->pL_child = NULL;
    pB->pR_child = NULL;
    pC->pL_child = pD;
    pC->pR_child = NULL;
    pD->pL_child = NULL;
    pD->pR_child = pE;
    pE->pL_child = NULL;
    pE->pR_child = NULL;

    return pA;
}
void Pre_traverse(pNODE pNode){
/*
 * 先      访问  根节点
 * 再 先序 访问  左子树
 * 再 先序 访问  右子树
 */
    if(NULL != pNode){
        printf("%c\t", pNode->data);
        if(NULL != pNode->pL_child){
            Pre_traverse(pNode->pL_child);
        }
        if(NULL != pNode->pR_child){
            Pre_traverse(pNode->pR_child);
        }
    }
}
void IN_traverse(pNODE pNode){
    if(NULL != pNode){
        if(NULL != pNode->pL_child){
            IN_traverse(pNode->pL_child);
        }
        printf("%c\t", pNode->data);
        if(NULL != pNode->pR_child){
            IN_traverse(pNode->pR_child);
        }
    }
}
void Post_traverse(pNODE pNode){
    if(NULL != pNode){
        if(NULL != pNode->pL_child){
            Post_traverse(pNode->pL_child);
        }
        if(NULL != pNode->pR_child){
            Post_traverse(pNode->pR_child);
        }
        printf("%c\t", pNode->data);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值