二叉树的先序遍历详解(小白也懂)(附带中序,后序代码)

本文详细介绍了二叉树的先序遍历算法,通过递归方式实现,以一个具体的二叉树为例,展示了遍历过程和运行结果。
摘要由CSDN通过智能技术生成

二叉树的先序遍历(分而治之思想)

代码在文章底部。

先序遍历又叫先根遍历,顾名思义:遍历顺序为根,左子树,右子树

样例图

本文将对以下二叉树进行遍历

在这里插入图片描述
先上代码:先序遍历的核心代码。

void PreOrder(BiTNode* T)
{
	if (T == NULL)
	{
		cout << "NULL ";
		return;
	}
	cout << T->data << " ";
	PreOrder(T->lchild);
	PreOrder(T->rchild);
}

先序遍历的运行结果:
A B D E C
在这里插入图片描述

函数的递归调用

在这里插入图片描述

解释:第一步:从A结点开始打印,打印A结点,进入A的左子树。

第二步:打印B结点,进入B的左子树。

第三步:打印D结点,进入D的左子树。

第四步:D的左子树为空, 打印 NULL , 返回上一步,打印D的右子树。

第五步:进入D的右子树。

第六步: D的右子树为空,打印 NULL , 返回上一步。

第七步:此处的代码运行结束,返回上一步。

第八步:进入B的右子树,打印E

第九步:进入E的左子树。

第十步:打印E的左子树,打印NULL,返回上一步,打印E的右子树。

第十一步:进入E的右子树。

第十二步:打印E的右子树,打印NULL,返回上一步,此处的函数运行结束。

第十三步:此处的函数运行结束,返回上一步。

第十四步:此处的函数运行结束,返回上一步。

第十五步:进入A的右子树,打印C

第十六步:进入C的左子树。

第十七步:C的左子树为空, 打印 NULL , 返回上一步,打印C的右子树。

第十八步:进入C的右子树。

第十九步:C的右子树为空, 打印 NULL , 返回上一步。

第二十步:此处函数运行结束,继续返回上一步。

到此程序的运行就结束了。

源代码

#include<iostream>
using namespace std;
typedef char ElemType;

typedef struct BiTNode {
	ElemType data;           //数据域
	struct BiTNode* lchild;  //左孩子指针
	struct BiTNode* rchild;	 //右孩子指针
}BiTNode;

//先序排序
void PreOrder(BiTNode* T)
{
	if (T == NULL)
	{
		cout << "NULL ";
		return;
	}
	cout << T->data << " ";
	PreOrder(T->lchild);
	PreOrder(T->rchild);
}

//中序排序
void InOrder(BiTNode* T)
{
	if (T == NULL)
	{
		cout << "NULL ";
		return;
	}
	PreOrder(T->lchild);
	cout << T->data << " ";
	PreOrder(T->rchild);
}
//后序排序
void PostOrder(BiTNode* T)
{
	if (T == NULL)
	{
		cout << "NULL ";
		return;
	}
	PreOrder(T->lchild);
	PreOrder(T->rchild);
	cout << T->data << " ";
}
int main()
{
	//快速创建一个树
	BiTNode* A = (BiTNode*)malloc(sizeof(BiTNode));
	A->data = 'A';
	A->lchild = NULL;
	A->rchild = NULL;

	BiTNode* B = (BiTNode*)malloc(sizeof(BiTNode));
	B->data = 'B';
	B->lchild = NULL;
	B->rchild = NULL;

	BiTNode* C = (BiTNode*)malloc(sizeof(BiTNode));
	C->data = 'C';
	C->lchild = NULL;
	C->rchild = NULL;

	BiTNode* D = (BiTNode*)malloc(sizeof(BiTNode));
	D->data = 'D';
	D->lchild = NULL;
	D->rchild = NULL;

	BiTNode* E = (BiTNode*)malloc(sizeof(BiTNode));
	E->data = 'E';
	E->lchild = NULL;
	E->rchild = NULL;

	A->lchild = B;
	A->rchild = C;
	B->lchild = D;
	B->rchild = E;
	cout << "先序排序: ";
	PreOrder(A);
	cout << endl;

	cout << "中序排序: ";
	InOrder(A);
	cout << endl;

	cout << "后序排序: ";
	PostOrder(A);
	cout << endl;

	return 0;
}

运行结果

在这里插入图片描述
觉得我回答有用的话,记得点个关注哟!谢谢支持!

  • 9
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
已知二叉树的前序遍历和后序遍历,可以推导出中序遍历。但需要注意的是,只有给定前序遍历和后序遍历是无法唯一确定一棵二叉树的,因此以下的解法也仅给出一种可能的中序遍历。 具体做法如下: 1. 根据前序遍历的第一个节点,确定根节点。 2. 在后序遍历中找到该根节点的位置,可以将后序遍历分为两个部分:左子树的后序遍历和右子树的后序遍历。 3. 在前序遍历中,根据左子树的节点个数,可以将前序遍历分为三个部分:根节点、左子树的前序遍历和右子树的前序遍历。 4. 对左子树和右子树分别递归进行上述步骤,直到遍历完所有节点。 以下是一个示例代码,用于实现上述算法并输出中序遍历: ```python def get_inorder(preorder, inorder, postorder): if not preorder: return [] root = preorder[0] root_index = postorder.index(root) left_size = root_index + 1 left_preorder = preorder[1:1+left_size] left_inorder = inorder[:left_size-1] left_postorder = postorder[:root_index+1] right_preorder = preorder[1+left_size:] right_inorder = inorder[left_size:] right_postorder = postorder[root_index+1:-1] left_inorder = get_inorder(left_preorder, left_inorder, left_postorder) right_inorder = get_inorder(right_preorder, right_inorder, right_postorder) return left_inorder + [root] + right_inorder preorder = [1, 2, 4, 5, 3, 6, 7] inorder = [4, 2, 5, 1, 6, 3, 7] postorder = [4, 5, 2, 6, 7, 3, 1] print(get_inorder(preorder, inorder, postorder)) # 输出 [4, 2, 5, 1, 6, 3, 7] ``` 在上述代码中,`get_inorder` 函数接收三个参数:前序遍历、中序遍历和后序遍历。如果前序遍历为空,则返回一个空列表。否则,首先根据前序遍历的第一个节点确定根节点,然后在后序遍历中找到该根节点的位置,并计算出左子树的节点个数。接着,根据左子树的节点个数,将前序遍历、中序遍历和后序遍历分为左子树和右子树三部分。对左子树和右子树分别递归进行上述步骤,并将结果合并,得到最终的中序遍历。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

君生我老

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值