桃夭~ 2021-11-18 21:40 采纳率: 0%
浏览 33

求二叉树的叶子节点个数

假设二叉树采用二叉链存储结构存储,设计一个算法计算一棵给定二叉树的所有叶子节点个数。

  • 写回答

1条回答 默认 最新

  • CSDN专家-Time 2021-11-19 17:16
    关注
    #include<iostream>
    using namespace std;
    
    //二叉树节点
    struct BinaryNode
    {
        char ch;
        BinaryNode* lchild;
        BinaryNode* rchild;
    };
    void CaculateLeafNum(BinaryNode* root);
    int Leaf_Count = 0;  //不能定义在CaculateLeafNum()函数内。
    void CaculateLeafNum(BinaryNode* root) {
        if (!root) return;
        if (root->lchild == NULL && root->rchild == NULL) Leaf_Count++;
    
        CaculateLeafNum(root->lchild);
        CaculateLeafNum(root->rchild);
    }
    
    //初始化二叉树
    void CreateBinaryTree() {
        BinaryNode node1 = { 'A',NULL,NULL };
        BinaryNode node2 = { 'B',NULL,NULL };
        BinaryNode node3 = { 'C',NULL,NULL };
        BinaryNode node4 = { 'D',NULL,NULL };
        BinaryNode node5 = { 'E',NULL,NULL };
        BinaryNode node6 = { 'F',NULL,NULL };
        BinaryNode node7 = { 'G',NULL,NULL };
        BinaryNode node8 = { 'H',NULL,NULL };
        //建立节点关系
        node1.lchild = &node2;
        node1.rchild = &node6;
        node2.rchild = &node3;
        node3.lchild = &node4;
        node3.rchild = &node5;
        node6.rchild = &node7;
        node7.lchild = &node8;
        CaculateLeafNum(&node1);  //调用函数
        cout << "Num of Leaf:" << Leaf_Count << endl;
    }
    //二叉树遍历
    
    int main() {
        CreateBinaryTree();
    }
    
    评论

报告相同问题?

问题事件

  • 创建了问题 11月18日

悬赏问题

  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥20 想用ollama做一个自己的AI数据库
  • ¥15 关于qualoth编辑及缝合服装领子的问题解决方案探寻
  • ¥15 请问怎么才能复现这样的图呀