数据结构 ——— 计算链式二叉树叶子节点的个数以及计算链式二叉树的高度

目录

前言

链式二叉树示意图​编辑

手搓一个链式二叉树

计算链式二叉树的叶子节点个数

计算链式二叉树的高度


前言

上一章学习了计算链式二叉树的节点个数

数据结构 --------- 计算链式二叉树节点的个数-CSDN博客

接下来学习的是计算链式二叉树叶子节点的个数以及计算链式二叉树的高度


链式二叉树示意图


手搓一个链式二叉树

代码演示:

复制代码
// 数据类型
typedef int BTDataType;
 
// 二叉树节点的结构
typedef struct BinaryTreeNode
{
    BTDataType data; //每个节点的数据
 
    struct BinaryTreeNode* left; //指向左子树的指针
 
    struct BinaryTreeNode* right; //指向右子树的指针
}BTNode;
 
// 申请新节点
BTNode* BuyNode(BTDataType x)
{
    BTNode* newnode = (BTNode*)malloc(sizeof(BTNode));
 
    // 判断是否申请成功
    if (newnode == NULL)
    {
        perror("malloc fail");
        return NULL;
    }
 
    // 初始化
    newnode->data = x;
    newnode->left = NULL;
    newnode->right = NULL;
 
    return newnode;
}
 
BTNode* CreatBinaryTree()
{
    BTNode* n1 = BuyNode(1);
    assert(n1);
    BTNode* n2 = BuyNode(2);
    assert(n2);
    BTNode* n3 = BuyNode(3);
    assert(n3);
    BTNode* n4 = BuyNode(4);
    assert(n4);
    BTNode* n5 = BuyNode(5);
    assert(n5);
    BTNode* n6 = BuyNode(6);
    assert(n6);
 
    n1->left = n2;
    n1->right = n4;
    n2->left = n3;
    n4->left = n5;
    n4->right = n6;
 
    return n1;
}

计算链式二叉树的叶子节点个数

代码演示:

复制代码
int BtreeLeafSize(BTNode* root)
{
	if (root == NULL)
		return 0;

	if (root->left == NULL && root->right == NULL)
		return 1;

	return BtreeLeafSize(root->left) + BtreeLeafSize(root->right);
}

代码解析:

当 root 为空时,说明没有节点,返回 0

当 root 的 left 和 root 的 right 为空时,就说明 root 为叶子节点,返回 1

通过 BTreeLeafSize 函数递归找到二叉树的所有叶子节点

大致走读代码(以上图为例):

进入函数,root 为 1 节点,那么就会走 BTreeLeafSize(root->left)

直到走到 root 为 3 节点,root 的 left 和 root 的 right 都为空,那么说明当前 root 为叶节点

返回 1 ,注意:并不是直接返回,而是返回到上一层,也就是 root 为 2 节点时

因为 2 节点的 right 为空,所当 root 为 2 节点的 right 时,返回 0

返回到 root 为 节点 1 时,那么就会走 BTreeLeafSize(root->right)..................

最后递归完之后,返回的值,就是链式二叉树的叶子节点个数

代码验证:


计算链式二叉树的高度(分治算法)

代码演示:

复制代码
int BTreeHeight(BTNode* root)
{
	if (root == NULL)
		return 0;

	int leftHeight = BTreeHeight(root->left);
	int rightHeight = BTreeHeight(root->right);

	return leftHeight > rightHeight ? leftHeight + 1 : rightHeight + 1;
}

代码解析:

当 root 为空时,说明没有节点,返回 0

创建两个变量用来记录左右子树的节点高度

最后再比较,返回高的那个节点的高度,也就是整个二叉树的高度

大致走读代码(以上图为例):

进入函数,root 为 1 节点,先走 BTreeHeight(root->left)

直到 root 为 3 节点的 left 节点,为空返回 0,返回到 3 节点

再走 BTreeHeight(root->right) ,也就是 3 节点的 right 节点,同样为空返回 0

此时的 leftHeight 和 rightHeight 同样为 0,返回 0+1

也就是返回到 root 为 2 节点的时候,且 2 节点的 right 为空,返回 0

此时 2 节点的 leftHeight 为 1,rightHeight 为 0,比较后,返回 1+1

返回的 2 返回到 root 为 1节点的时候,再走 BTreeHeight(root->right)..................

直到递归走完,最后返回的结果就是左右子树比较大的值,也就是二叉树的高

代码验证:

相关推荐
仰泳的熊猫2 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
无极低码5 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
爱编码的小八嘎5 小时前
C语言完美演绎4-7
c语言
软件算法开发6 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
罗超驿6 小时前
独立实现双向链表_LinkedList
java·数据结构·链表·linkedlist
superior tigre6 小时前
22 括号生成
算法·深度优先
炘爚7 小时前
C语言(文件操作)
c语言·开发语言
努力也学不会java7 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
W.D.小糊涂7 小时前
gpu服务器安装windows+ubuntu24.04双系统
c语言·开发语言·数据库