开发者社区> 问答> 正文

编写递归算法,求二叉树的结点个数和叶子数

编写递归算法,求二叉树的结点个数和叶子数

展开
收起
知与谁同 2018-07-18 15:21:53 2039 0
2 条回答
写回答
取消 提交回答
  • 阿里云开发者社区运营负责人。原云栖社区负责人。
    输入格式是怎么样的啊。
    2019-07-17 22:54:50
    赞同 展开评论 打赏
  • 云栖社区聚能聊、问答管理员~发福利、搞怪,八卦我来,论技术、发话题、写博客你上!
    0?0DLR(liuyu *root) /*中序遍历 递归函数*/
    {if(root!=NULL)
    {if((root->lchild==NULL)&&(root->rchild==NULL)){sum++; printf("%d\n",root->data);}
    DLR(root->lchild);
    DLR(root->rchild); }
    return(0);
    }
    法二:
    int LeafCount_BiTree(Bitree T)//求二叉树中叶子结点的数目
    {
    if(!T) return 0; //空树没有叶子
    else if(!T->lchild&&!T->rchild) return 1; //叶子结点
    else return Leaf_Count(T->lchild)+Leaf_Count(T->rchild);//左子树的叶子数加
    上右子树的叶子数
    }//LeafCount_BiTree

    注:上机时要先建树。例如实验二的方案一。
    ① 打印叶子结点值(并求总数)
    思路:先建树,再从遍历过程中打印结点值并统计。

    -------------------------

    写了个比较简单的,包括建立二叉树,还有你需要的递归函数,不懂可追问

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

    #define CURRENT 0
    #define LEFT 1
    #define RIGHT 2

    typedef struct BiTree
    {
    char data; //数据
    BiTree* lchild; //左孩子节点
    BiTree* rchild; //右孩子节点
    BiTree* parent; //父节点
    }BiTree;

    void InitBiTree(BiTree* tree) //构造空二叉树
    {
    tree = NULL;
    }

    void CreateTree(BiTree* tree, char data) //给二叉树赋值
    {
    tree->data = data;
    tree->parent = NULL;
    tree->lchild = NULL;
    tree->rchild = NULL;
    }

    int InsertChild(BiTree* tree, int pos, char data) //给孩子节点赋值
    {
    if (pos == LEFT)
    {
    if (tree->lchild != NULL)
    {
    printf("insert left child error!\n");
    return false;
    }
    BiTree* t = (BiTree*)malloc(sizeof(BiTree));
    tree->lchild = t;
    t->data = data;
    t->lchild = NULL;
    t->rchild = NULL;
    t->parent = tree;
    return 1;
    }
    else if (pos == RIGHT)
    {
    if (tree->rchild != NULL)
    {
    printf("insert right child error!\n");
    return 0;
    }
    BiTree* t = (BiTree*)malloc(sizeof(BiTree));
    tree->rchild = t;
    t->data = data;
    t->lchild = NULL;
    t->rchild = NULL;
    t->parent = tree;
    return 1;
    }
    return 0;
    }

    int PreOrderTraverse(BiTree* tree, int* countchildren, int* countleaves) // 递归函数
    {
    BiTree* p = tree;
    if (p)
    {
    (*countchildren)++; // 如果那个节点有数据,就增加子节点数
    int lnull, runll;
    if (lnull = PreOrderTraverse(p->lchild, countchildren, countleaves))
    {
    if (runll = PreOrderTraverse(p->rchild, countchildren, countleaves))
    {
    if (lnull == -1 && runll == -1) // 如果左右节点都为空,则增加叶子节点数
    {
    (*countleaves)++;
    }
    return 1;
    }
    }
    return 0;
    }
    else
    {
    return -1;
    }
    }

    int main()
    {
    BiTree bt;
    int countchildren = 0;
    int countleaves = 0;
    InitBiTree(&bt);
    CreateTree(&bt, 's');
    InsertChild(&bt, LEFT, 'i');
    InsertChild(bt.lchild, LEFT, 'A');
    InsertChild(bt.lchild->lchild, LEFT, 'x');
    InsertChild(bt.lchild, RIGHT, 'B');
    InsertChild(bt.lchild->rchild, RIGHT, 'y');
    InsertChild(&bt, RIGHT, 'o');
    PreOrderTraverse(&bt, &countchildren, &countleaves);
    printf("countchildren : %d\n", countchildren);
    printf("countleaves : %d\n", countleaves);
    return 0;
    }

    2019-07-17 22:54:49
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
数据+算法定义新世界 立即下载
袋鼠云基于实时计算的反黄牛算法 立即下载
Alink:基于Apache Flink的算法平台 立即下载