求二叉树b的结点个数、叶子结点个数

这段代码实现了一个计算二叉树节点个数和叶子节点个数的程序。通过递归遍历二叉树的左右子树,分别计算节点总数和叶子节点数。`Nodes`函数返回整棵树的节点数,而`LeafNodes`函数返回叶子节点数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include"tree.cpp"		//包含了二叉树的基本算法

/*--------
求二叉树b的结点个数、叶子结点个数 
---------*/

//求二叉树b的结点个数
int Nodes(BTNode *b){
	int num1,num2;
	if(b==NULL)
		return 0;
	else if(b->lchild==NULL && b->rchild==NULL)		//只有根结点
		return 1;
	else{
		num1 = Nodes(b->lchild);	//递归遍历左子树
		num2 = Nodes(b->rchild);	//递归遍历右子树
		return(num1+num2+1);		//每次递归返回 左结点个数+右结点个数+根结点 
	} 
} 

//求二叉树b的叶子结点个数
int LeafNodes(BTNode *b){
	int num1,num2;
	if(b==NULL)
		return 0;
	else if(b->lchild==NULL && b->rchild==NULL)
		return 1;
		else{
		num1 = Nodes(b->lchild);	//递归遍历左子树
		num2 = Nodes(b->rchild);	//递归遍历右子树
		return(num1+num2);		//每次递归返回 左叶结点个数+右叶结点个数 
	}
} 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值