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

我们来了解一下二叉树的遍历,话不多说

二叉树的遍历的概念:

二叉树有四种遍历方式,分别为前序遍历,中序遍历,后序遍历和层序遍历,但我们今天谈谈前三种,并实现它

前序遍历: 按照根,左子树,右子树的顺序进行遍历,方便记忆:根左右

中序遍历: 按照左子树,根,右子树的顺序进行遍历,方便记忆:左根右

后序遍历: 按照左子树,右子树,根的顺序进行遍历,方便记忆:左右根

注意:对于左右子树,是相对于每个根结点来说的,遍历时必须直到最后为空时,再往上返回

看了概念依然会有很多人不解(包括我),所以我们接下来来用中序遍历的例子帮助我们更好地理解

根据中序遍历的左根右的顺序,和上图的方向,我们可以写出中序遍历的顺序结构形式了:

递归代码实现:

创建二叉树:

我们定义数据域和指针域,指针域为树的左右结点

复制代码
typedef int BTDataType;
typedef struct BinaryTreeNode
{
	BTDataType data;//数据域
	struct BinaryTreeNode* left;
	struct BinaryTreeNode* right;
}BTNode;

前中后序遍历:

我们通过中序遍历发现当它往下调用完之后会往上返回,这符合递归的调用的方式

复制代码
//前序遍历--根左右
void PreOrder(BTNode* root)
{
	if (root == NULL)//递归函数的出口
	{
		printf("NULL ");
		return;
	}

	printf("%d ", root->data);
	PreOrder(root->left);
	PreOrder(root->right);
}
//中序遍历--左根右
void MidOrder(BTNode* root)
{
	if (root == NULL)//递归函数的出口
	{
		printf("NULL ");
		return;
	}
	
	MidOrder(root->left);
	printf("%d ", root->data);
	MidOrder(root->right);
}
//后序遍历--左右根
void AftOrder(BTNode* root)
{
	if (root == NULL)//递归函数的出口
	{
		printf("NULL ");
		return;
	}
	
	AftOrder(root->left);
	AftOrder(root->right);
	printf("%d ", root->data);
}
相关推荐
汀、人工智能5 小时前
[特殊字符] 第40课:二叉树最大深度
数据结构·算法·数据库架构·图论·bfs·二叉树最大深度
赫瑞6 小时前
数据结构中的排列组合 —— Java实现
java·开发语言·数据结构
大熊背6 小时前
ISP Pipeline中Lv实现方式探究之三--lv计算定点实现
数据结构·算法·自动曝光·lv·isppipeline
yuannl1010 小时前
数据结构----队列的实现
数据结构
Mr_Xuhhh10 小时前
从ArrayList到LinkedList:理解链表,掌握Java集合的另一种选择
java·数据结构·链表
Ricardo-Yang12 小时前
SCNP语义分割边缘logits策略
数据结构·人工智能·python·深度学习·算法
soragui13 小时前
【Python】第 4 章:Python 数据结构实现
数据结构·windows·python
samroom13 小时前
【鸿蒙应用开发 Dev ECO Studio 5.0版本】从0到1!从无到有!最全!计算器------按钮动画、滑动退格、中缀表达式转后缀表达式、UI设计
数据结构·ui·华为·typescript·harmonyos·鸿蒙
算法鑫探14 小时前
10个数下标排序:最大值、最小值与平均值(下)
c语言·数据结构·算法·排序算法·新人首发
王老师青少年编程14 小时前
csp信奥赛c++之状压枚举
数据结构·c++·算法·csp·信奥赛·csp-s·状压枚举