二叉树的递归遍历应用

分别设计三个方法,计算二叉树 度为1的结点个数,度为2的结点的个数,以及树的结点个数。

要求:1.构建如下二叉树:

           A 

         /   \

        B     C

       / \   /

      D   E F

/* 二叉树的结点结构 */

#include <stdio.h>
#include <malloc.h>
typedef char ElemType;         /* 数据域值类型 */
typedef struct Node {
    ElemType data;               /* 数据域 */
    struct Node *lchild, *rchild; /* 左、右指针域,分别存储左、右孩子的存储位置 */
} BinaryTree;


/*1. 先序建立二叉树 */

BinaryTree *CreBiTree( ) {
    BinaryTree *bt;
    ElemType x;
    scanf("%c", &x);               /* 读入数据 */
    if (x == '^') bt = NULL;       /* 输入^,安排空指针 */
    else {
        bt = (BinaryTree *)malloc(sizeof(BinaryTree));
        bt->data = x;                /* 生成新结点 */
        bt->lchild = CreBiTree();    /* 建立左子树 */
        bt->rchild = CreBiTree();    /* 建立右子树 */
    }
    return bt;                     /* 返回根结点的指针 */
}


/* 先序遍历二叉树的递归算法 */
void PreOrder(BinaryTree *bt) {
    if (bt != NULL) {
        printf("%c", bt->data);   /* 访问根结点 */
        PreOrder(bt->lchild);     /* 先序遍历根结点的左子树 */
        PreOrder(bt->rchild);     /* 先序遍历根结点的右子树 */
    }
}


/* 中序遍历二叉树的递归算法 */
void InOrder(BinaryTree *bt) {
    if (bt != NULL) {
        InOrder(bt->lchild);     /* 中序遍历根结点的左子树 */
        printf("%c", bt->data);  /* 访问根结点 */
        InOrder(bt->rchild);     /* 中序遍历根结点的右子树 */
    }
}


/* 后序遍历二叉树的递归算法 */
void PostOrder(BinaryTree *bt) {
    if (bt != NULL) {
        PostOrder(bt->lchild);   /* 后序遍历根结点的左子树 */
        PostOrder(bt->rchild);   /* 后序遍历根结点的右子树 */
        printf("%c", bt->data);  /* 访问根结点 */
    }
}

int LeafCount(BinaryTree *bt) {
    static int count = 0;
    if (bt != NULL) {
        if (bt->lchild == NULL && bt->rchild == NULL)
            count++;
        else {
            LeafCount(bt->lchild);
            LeafCount(bt->rchild);
        }
    }

    return count;
}
int LeafCountt(BinaryTree *bt) {
    if (bt == NULL)
        return 0;
    if (bt->lchild == NULL && bt->rchild == NULL)
        return 1;

    return LeafCountt(bt->lchild) + LeafCountt(bt->rchild);
}
//度为1
int LeafCount_1(BinaryTree *bt) {
    if (bt == NULL)
        return 0;
    else if ((bt->lchild == NULL && bt->rchild != NULL) || (bt->lchild != NULL && bt->rchild == NULL))
        return LeafCount_1(bt->lchild) + LeafCount_1(bt->rchild) + 1;
    else
        return LeafCount_1(bt->lchild) + LeafCount_1(bt->rchild);
}
//度为2
int LeafCount_2(BinaryTree *bt) {
    if (bt == NULL)
        return 0;
    else if (bt->lchild != NULL && bt->rchild != NULL)
        return LeafCount_2(bt->lchild) + LeafCount_2(bt->rchild) + 1;
    return LeafCount_2(bt->lchild) + LeafCount_2(bt->rchild);
}
//结点总数
int LeafCount_All(BinaryTree *bt) {
    if (bt == NULL)
        return 0;
    else
        return LeafCount_All(bt->lchild) + LeafCount_All(bt->rchild) + 1;
}

int main() {
    BinaryTree *bt;
    printf("input data:");
    bt = CreBiTree();           /* 可以图5.13为例建立二叉链表  ABD^^E^^CF^^^ */

    printf("PreOrder result:");
    PreOrder(bt);
    printf("\n");
//
//  printf("InOrder result:");
//  InOrder(bt);
//  printf("\n");
//
//  printf("PostOrder result:");
//  PostOrder(bt);
//  printf("\n");

//  printf("叶子节点的个数为:%d\n",LeafCountt(bt));
    printf("度为1结点的个数为:%d\n", LeafCount_1(bt));
    printf("度为2结点的个数为:%d\n", LeafCount_2(bt));
    printf("结点总个数为:%d\n", LeafCount_All(bt));
}

  • 13
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
【优质项目推荐】 1、项目代码均经过严格本地测试,运行OK,确保功能稳定后才上传平台。可放心下载并立即投入使用,若遇到任何使用问题,随时欢迎私信反馈与沟通,博主会第一时间回复。 2、项目适用于计算机相关专业(如计科、信息安全、数据科学、人工智能、通信、物联网、自动化、电子信息等)的在校学生、专业教师,或企业员工,小白入门等都适用。 3、该项目不仅具有很高的学习借鉴价值,对于初学者来说,也是入门进阶的绝佳选择;当然也可以直接用于 毕设、课设、期末大作业或项目初期立项演示等。 3、开放创新:如果您有一定基础,且热爱探索钻研,可以在此代码基础上二次开发,进行修改、扩展,创造出属于自己的独特应用。 欢迎下载使用优质资源!欢迎借鉴使用,并欢迎学习交流,共同探索编程的无穷魅力! 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值