【C++课程学习】:二叉树的基本函数实现

🎁个人主页:我们的五年

🔍系列专栏:C++课程学习

🎉欢迎大家点赞👍评论📝收藏⭐文章

目录

🍉二叉树的结构类型:

🍉1.创建二叉树函数(根据数组,前序遍历创建二叉树):

🍉2.销毁二叉树函数:

🍉3.前序遍历函数:

🍉4.二叉树的节点个数函数:

🍉5.计算二叉树叶子节点的个数函数:

🍉6.计算第k层的节点个数:

🍉7.查找节点为k的元素,返回这个元素的指针

🍉8.层序遍历,借助队列:

🍉判断是否为完全二叉树:


前言:

学了那么久的二叉树,现在基本的二叉树学的差不多了,现在就给大家带来二叉树的几个基本函数。函数有几个,但是基本都不难,基本就是用了分治,递归的思想,画递归展开图也是一种很好理解递归过程好方法,等熟悉以后,就对递归有了更深的理解,面对有一些问题就直接可以写出来。

🍉二叉树的结构类型:

//二叉树的节点结构类型
typedef struct BinaryTreeNode {
BTDataType data;
struct BinaryTreeNode* left; //左孩子节点的地址
struct BinaryTreeNode* right; //右孩子的地址
}BTNode;

每个父节点都包:

1.含存储的数据。

2.左孩子地址。

3.右孩子节点的地址。

🍉1.创建二叉树函数(根据数组,前序遍历创建二叉树):

画递归展开图也是很好理解的,先创建父亲节点,然后往左走,遇到'#',就返回NULL,返回上一层。

复制代码
//根据数组创建二叉树,下面举例的是字符数组,创建的顺序是前序遍历
BTNode* BinaryTreeCreate(BTDataType* a, int* pi)
{
	if (a[*pi] == '#')
	{
		(*pi)++;
		return NULL;
	}
	BTNode* root = (BTNode*)malloc(sizeof(BTNode));
	root->data = a[*pi];	//前序遍历,先创建中间根节点
	(*pi)++;
	root->left = BinaryTreeCreate(a,pi);	//左子树
	root->right = BinaryTreeCreate(a,pi);	//右子树
	return root;	//返回root节点
}

🍉2.销毁二叉树函数:

销毁二叉树也可以前序遍历删除,也可以中序删除。不过如果是前序删除,就要在先保存左右孩子的节点。如果是中序删除,就是要保存右节点。

只有后序遍历删除不要保存节点。

复制代码
// 二叉树销毁
void BTDestory(BTNode** root)
{
	if (*root == NULL)
		return;
    //后序遍历销毁二叉树
	BTDestory(&(*root)->left);
	BTDestory(&(*root)->right);
	free(*root);
	*root = NULL;
}

🍉3.前序遍历函数:

前序遍历和中序遍历和后序遍历基本差不多,只有后面的两个函数和打印的顺序不一样。

复制代码
//前序遍历
void BTPreOreder(BTNode* root)
{
	if (root == NULL)
	{
		printf("# ");
		return;
	}
	printf("%c ",root->data);
	BTPreOreder(root->left);
	BTPreOreder(root->right);
}

🍉4.二叉树的节点个数函数:

分治思想也是yyds

复制代码
// 二叉树节点个数
int BTSize(BTNode* root)
{
	if (root == NULL)
		return 0;
    //个数等于左树节点个数+右树节点个数+1
	return BTSize(root->left)+BTSize(root->right)+1;
}

🍉5.计算二叉树叶子节点的个数函数:

分治

复制代码
// 二叉树叶子节点个数
int BinaryTreeLeafSize(BTNode* root)
{	if (root == NULL)
		return 0;
	if (root->left == NULL && root->right == NULL)
		return 1;
	return BinaryTreeLeafSize(root->left) + BinaryTreeLeafSize(root->right);
}

🍉6.计算第k层的节点个数:

要注意的是,遇到NULL,要返回,还有就是,k==1,return 1,要在后面,因为如果在前面,k确实等于1。但是这时候是空节点,所以不能return 1,所以return 1要在后面。

复制代码
// 二叉树第k层节点个数
int BinaryTreeLevelKSize(BTNode* root, int k)
{
	if (root == NULL)
		return 0;
	if (k == 1)
	{
		return 1;
	}
	return BinaryTreeLevelKSize(root->left, k - 1)+ BinaryTreeLevelKSize(root->right,k-1);
}

🍉7.查找节点为k的元素,返回这个元素的指针

找父节点,父节点不是,就去左树,左树没有,就去右树。

只要找到了就返回,所以是或的关系;

复制代码
// 二叉树查找值为x的节点
BTNode* BinaryTreeFind(BTNode* root, BTDataType x)
{
	if (root == NULL)
		return NULL;
	if (root->data == x)
		return root;
	BTNode* p1 = BinaryTreeFind(root->left, x);
	if (p1!=NULL)
		return p1;
	BTNode* p2 = BinaryTreeFind(root->right, x);
	if (p2!=NULL)
		return p2;
	return NULL;
}

🍉8.层序遍历,借助队列:

先在队列中插入root,在队列头出一个数据,就入这个节点的左右孩子节点。因为队列有先进先出的特点,所以能达到层序的目的。

复制代码
// 层序遍历
void BinaryTreeLevelOrder(BTNode* root)
{
	Queue ps;
	QueueInit(&ps);
	QueuePush(&ps, root);
	while (!QueueEmpty(&ps))
	{
		BTNode* node = QueueTop(&ps);
		if (node == NULL)
		{
			break;
		}
		else
		{
			printf("%c ", node->data);		
			QueuePush(&ps, node->left);
			QueuePush(&ps, node->right);
		}
		QueuePop(&ps);
	}
	QueueDestroy(&ps);
}

🍉9.判断是否为完全二叉树:

先入数据,然后出,和层序遍历一样,当需要NULL就结束。然后看后面的队列是否都是NULL,如果只要有一个不是NULL,那肯定就不是完全二叉树了,前面都有NULL,后面又出现节点。

复制代码
// 判断二叉树是否是完全二叉树
int BinaryTreeComplete(BTNode* root)
{
	Queue ps;
	QueueInit(&ps);
	QueuePush(&ps, root);
	while (!QueueEmpty(&ps))
	{
		BTNode* node = QueueTop(&ps);
		if (node == NULL)
		{
			break;
		}
		else
		{
			QueuePush(&ps, node->left);
			QueuePush(&ps, node->right);
		}
		QueuePop(&ps);
	}
	while (!QueueEmpty(&ps))
	{
		BTNode* node = QueueTop(&ps);
		if (node != NULL)
			return 0;
		QueuePop(&ps);
	}
	return 1;
}
相关推荐
2501_92473111几秒前
智慧矿山误报率↓83%!陌讯多模态融合算法在矿用设备监控的落地优化
人工智能·算法·目标检测·视觉检测
小晶晶京京3 分钟前
day38-HTTP
网络·网络协议·学习·http
炸膛坦客9 分钟前
C++ 学习与 CLion 使用:(四)常量和变量,包括字面常量和符号常量
开发语言·c++·学习
特立独行的猫a18 分钟前
C/C++三方库移植到HarmonyOS平台详细教程(补充版so库和头文件形式)
c语言·c++·harmonyos·napi·三方库·aki
zheshiyangyang22 分钟前
uni-app学习【pages】
前端·学习·uni-app
zh_xuan1 小时前
LeeCode 40.组合总和II
c语言·数据结构·算法
livemetee1 小时前
Flink2.0学习笔记:使用HikariCP 自定义sink实现数据库连接池化
大数据·数据库·笔记·学习·flink
fanzhix2 小时前
线性回归学习
学习·机器学习·线性回归
都叫我大帅哥2 小时前
动态规划:从懵逼到装逼,一篇让你彻底搞懂DP的终极指南
java·算法
wangluoqi2 小时前
c++ 数据结构-并查集、ST表 小总结
数据结构·c++