二叉树的建立,以及递归前中后序遍历二叉树

测试用例如图:

#include <stdio.h>
#include <stdlib.h>

#define TREE "+*E*D/CAB"

typedef int dt;
typedef struct NODE {
    
    dt          data;
    
    struct NODE *lp;
    
    struct NODE *rp;
    
} Node, *Nodep;


void first(Nodep ptr) {
    if (ptr) {
        printf("%c", ptr->data);
        first(ptr->lp);
        first(ptr->rp);
    }
}

void mid(Nodep ptr) {
    if (ptr) {
        mid(ptr->lp);
        printf("%c",ptr->data);
        mid(ptr->rp);
    }
}

void last(Nodep ptr) {
    if (ptr) {
        last(ptr->lp);
        last(ptr->rp);
        printf("%c", ptr->data);
        
    }
    
}


int main() {
    Nodep   root = NULL;
    Nodep   tnode = (Nodep)malloc(sizeof(Node));
    Nodep   pl = NULL;
    Nodep   pr = NULL;
    char s[] = TREE;
    
    //建立二叉树
    root = tnode;
    tnode->data = s[0];
    tnode->lp = NULL;
    tnode->rp = NULL;
    
    char *p = s + 1;
    while(*p) {
        //printf("%c", *p++);
        pl = (Nodep)malloc(sizeof(Node));
        pl->data = *p++;
        pl->lp = NULL;
        pl->rp = NULL;
        
        pr = (Nodep)malloc(sizeof(Node));
        pr->data = *p++;
        pr->lp = NULL;
        pr->rp = NULL;
        
        tnode->lp = pl;
        tnode->rp = pr;
        tnode = tnode->lp;
    }
    
    //test
    puts("Middle:");
    mid(root);
    puts("");
    
    puts("First:");
    first(root);
    puts("");
    
    puts("Last:");
    last(root);
    puts("");
    puts("");
    
    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值