C语言二叉树叶子节点的求法

C语言叶子节点的求法可以用递归来实现

1、使用递归实现叶子结点的求法

C语言中的二叉树叶子节点求法是一个比较基础的问题。在二叉树中,叶子节点是指没有子节点的节点。为了求出二叉树中的叶子节点,我们可以采用递归算法。

具体来说,我们可以使用一个函数来遍历整棵二叉树,可以定义一个全局变量,用来统计叶子节点的数量。

用递归的思路来求叶子节点。

//找叶子节点数
int n = 0;
int LeafNode(PBTREE root)//传入根节点
{
	if (root != NULL)//判断非空
	{
		if (root->Lchild == NULL && root->Rchild == NULL)//如果叶子节点的话,左右节点都为空,则进行n++
		{
			n++;
		}
		LeafNode(root->Lchild);
		LeafNode(root->Rchild);
	}
	return n;//返回每一次函数调用n的值
}

这里定义一个全局变量n,用来记录叶子节点的数量。通过调用LeafNode函数求得叶子节点的数量。这种叶子数量的求法是基于先序遍历来实现,通过一遍一遍找寻左右孩子是否都为空,从而使得变量n自增

除了用先序遍历来实现,也可以用中序遍历实现,还可以用后序遍历实现,原理都一样。就不细说了。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值