c语言编程实现二叉树的三种遍历算法 并针对一个二叉树列出三种遍历序列。功能要求:实现三种遍历算法、 70

c语言编程实现二叉树的三种遍历算法并针对一个二叉树列出三种遍历序列。功能要求:实现三种遍历算法、main()函数中创建一个二叉树并列出三种遍历结果... c语言编程实现二叉树的三种遍历算法 并针对一个二叉树列出三种遍历序列。功能要求:实现三种遍历算法、main()函数中创建一个二叉树并列出三种遍历结果 展开
 我来答
白雲深處是我家
2015-06-03 · TA获得超过381个赞
知道小有建树答主
回答量:203
采纳率:66%
帮助的人:234万
展开全部
#include <stdio.h>
#include <malloc.h>

typedef struct BTree {
    char data;
    struct BTree *lChild;
    struct BTree *rChild;
} BinTree;

BinTree *CreateTree(BinTree *p) {
    char ch;
    scanf("%c", &ch);
    if (ch=='#') return NULL;
    p = (BinTree *)malloc(sizeof(BinTree));
    p->data = ch;
    p->lChild = CreateTree(p->lChild);
    p->rChild = CreateTree(p->rChild);
    return p;
}

int SumLeaf(BinTree *T) {
    int sum=0, m, n;
    if (T) {
        if ((!T->lChild) && (!T->rChild))
            sum++;
        m = SumLeaf(T->lChild);
        n = SumLeaf(T->rChild);
        sum +=m+n;
    }
    return sum;
}

void QianXu(BinTree *T) {
    if (T) {
        printf("%c, ", T->data);
        QianXu(T->lChild);
        QianXu(T->rChild);
    }
}

void ZhongXu(BinTree *T) {
    if (T) {
        ZhongXu(T->lChild);
        printf("%c,", T->data);
        ZhongXu(T->rChild);
    }
}

void HouXu(BinTree *T) {
    if (T) {
        HouXu(T->lChild);
        HouXu(T->rChild);
        printf("%c,", T->data);
    }
}

int Depth(BinTree *T) {
    int dep = 0, depl, depr;
    if (!T) dep = 0;
    else {
        depl = Depth(T->lChild);
        depr = Depth(T->rChild);
        dep = 1+(depl>depr?depl:depr);
    }
    return dep;
}

void FreeTree(BinTree *T) {
    if (T) {
        FreeTree(T->lChild);
        FreeTree(T->rChild);
        free(T);
    }
}

int main() {
    BinTree *Tree = NULL;
    Tree = CreateTree(Tree);
    //前序遍历
    printf("QianXu Traversal:");
    QianXu(Tree);
    printf("\nZhongXu Traversal:");
    ZhongXu(Tree);
    printf("\nHouXu Traversal:");
    HouXu(Tree);

    printf("\nLeaf's number:%d\n", SumLeaf(Tree));
    printf("Tree's Depth:%d", Depth(Tree));

    FreeTree(Tree);
    return 0;
}

输入:#ABCD###E##FG#H##I#J##
输出:

freely_1985
2015-06-03 · TA获得超过1189个赞
知道小有建树答主
回答量:2807
采纳率:42%
帮助的人:418万
展开全部
可使用递归法创建。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
等待918402
2015-06-03
知道答主
回答量:79
采纳率:0%
帮助的人:22.8万
展开全部
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式