二叉树的几个递归问题

我的主页:Lei宝啊

愿所有美好如期而遇


前言:

二叉树的递归是二叉树很重要的问题,几乎解决二叉树的问题都要使用递归,接下来我们将解决二叉树几个最基础的递归问题。


目录

前言:

二叉树的前序,中序,后序遍历:

树的结构:

前序递归遍历:

中序递归遍历:

后续递归遍历:

求树的节点数:

求叶子节点数:

第k层节点数:


二叉树的前序,中序,后序遍历:

树的结构:

复制代码
typedef struct BT_Tree
{
	int data;
	struct BT_Tree* left;
	struct BT_Tree* right;
}BT_Tree;

前序递归遍历:

复制代码
void PrevOrder(BT_Tree* node)
{
	if (node == NULL)
		return;

	printf("%d ", node->data);
	PrevOrder(node->left);
	PrevOrder(node->right);		
}

黄瓜个图看看:


中序递归遍历:

复制代码
void InOrder(BT_Tree* node)
{
	if (node == NULL)
		return;
	
	PrevOrder(node->left);
	printf("%d ", node->data);
	PrevOrder(node->right);
}

花瓜个图看看:


后续递归遍历:

复制代码
void LastOrder(BT_Tree* node)
{
	if (node == NULL)
		return;

	PrevOrder(node->left);	
	PrevOrder(node->right);
	printf("%d ", node->data);
}

画个图看看:


求树的节点数:

复制代码
int SizeofNode(BT_Tree* node)
{
	if (node == NULL)
		return 0;

	return SizeofNode(node->left) + SizeofNode(node->right) + 1;
}

画个图:


求叶子节点数:

复制代码
int SizeofLeaf(BT_Tree* node)
{
	if (node == NULL)
		return 0;
	if (node->left == NULL && node->right == NULL)
		return 1;

	return SizeofLeaf(node->left) + SizeofLeaf(node->right);
}

画图:


第k层节点数:

复制代码
int SizeInLineKNode(BT_Tree* node, int k)
{
	if (node == NULL)
		return 0;

	if (k == 1)
		return 1;

	return SizeInLineKNode(node->left, k - 1) + SizeInLineKNode(node->right, k - 1);
}

图:


相关推荐
仙俊红41 分钟前
LeetCode174双周赛T3
数据结构·算法
仍然.1 小时前
JavaDataStructure---二叉搜索树,哈希表,Map和Set
数据结构·散列表
程序员-King.2 小时前
链表——算法总结与新手教学指南
数据结构·算法·链表
FMRbpm3 小时前
树的练习6--------938.二叉搜索树的范围和
数据结构·c++·算法·leetcode·职场和发展·新手入门
多米Domi0113 小时前
0x3f 第35天 电脑硬盘坏了 +二叉树直径,将有序数组转换为二叉搜索树
java·数据结构·python·算法·leetcode·链表
程序员-King.4 小时前
day144—递归—平衡二叉树(LeetCode-110)
算法·leetcode·二叉树·递归
老鼠只爱大米5 小时前
LeetCode经典算法面试题 #394:字符串解码(递归、双栈、迭代构建等五种实现方案详解)
算法·leetcode·面试·递归··字符串解码
凯子坚持 c5 小时前
C++大模型SDK开发实录(一):spdlog日志封装、通用数据结构定义与策略模式应用
数据结构·c++·sdk·策略模式
漫随流水5 小时前
leetcode算法(513.找树左下角的值)
数据结构·算法·leetcode·二叉树
全栈游侠6 小时前
数据结构 -数组
数据结构