编写计算二叉树中叶子结点数目的算法

编写计算二叉树中叶子结点数目的算法

代码思路:

首先你要知道什么是叶子结点,就是一棵树的某个结点,它下面没有左右子树了,这个就叫叶子结点。知道这个之后,我们只需要一步步从根节点往下遍历,看哪个结点没有左右子树就count+1即可

ps:我们这里选择后序遍历------左右根,你选其他两种遍历方式也可以,毕竟这里只需要统计个数,没有要求你把序列写出来。只要能把一棵树完整遍历到就可以了。

c 复制代码
//二叉树结构体
typedef struct BiTNode
{
    char data;
    struct BiTNode* lchild, * rchild;
}BiTNode, * BiTree;

int count=0;

int leafcount(BiTree T){
	if(T!=NULL){//递归跳出条件
		leafcount(T->lchild);//访问左右孩子
		leafcount(T->rchild);
		if(T->lchild==NULL&&T->rchild==NULL){//该结点无左右子树
			count++;
		}
	}
	return count;
}
相关推荐
0 0 04 分钟前
CCF-CSP 33-2 相似度计算(jaccard)【C++】考点:STL容器(set/map)
开发语言·c++·算法
每天要多喝水7 分钟前
图论Day38:孤岛基础
算法·深度优先·图论
瓦特what?15 分钟前
波 浪 排 序
c++·算法·排序算法
blackicexs24 分钟前
第六周第日天
数据结构·算法
逆境不可逃24 分钟前
LeetCode 热题 100 之 48.旋转图像
算法·leetcode·职场和发展
Frostnova丶33 分钟前
LeetCode 1022. 从根到叶的二进制数之和
算法·leetcode
不会敲代码137 分钟前
别再背柯里化面试题了,看完这篇你自己也会写
javascript·算法·面试
snowfoootball39 分钟前
优先队列/堆 题目讲解
学习·算法
SamtecChina202339 分钟前
Samtec连接器设计研究 | 载流量:温升为什么重要?
大数据·网络·人工智能·算法·计算机外设
程序员南飞1 小时前
排序算法举例
java·开发语言·数据结构·python·算法·排序算法