二叉树的实现(纯C语言版)

目录

1.实现的接口

1.1通过前序遍历的数组"ABD##E#H##CF##G##"构建二叉树

// 通过前序遍历的数组"ABD##E#H##CF##G##"构建二叉树

BTNode* BinaryTreeCreate(BTDataType* a, int n, int* pi);

cpp 复制代码
if (a[*pi] == '#' || (*pi) >= n)
{
	(*pi)++;
	return NULL;
}
BTNode* root = (BTNode*)malloc(sizeof(BTNode));
root->_data = a[*pi];
(*pi)++;
root->_left = BinaryTreeCreate(a, n, pi);
root->_right = BinaryTreeCreate(a, n, pi);
return root;

1.2 二叉树销毁

// 二叉树销毁

void BinaryTreeDestory(BTNode** root);

cpp 复制代码
void BinaryTreeDestory(BTNode* root)
{
	if (root == NULL)
		return;
	BinaryTreeDestory(root->_left);
	BinaryTreeDestory(root->_right);
	free(root);
}

1.3二叉树节点个数

// 二叉树节点个数

int BinaryTreeSize(BTNode* root);

cpp 复制代码
int BinaryTreeSize(BTNode* root)
{
	if (root == NULL)
		return 0;
	static size = 0;
	size++;
	BinaryTreeSize(root->_left);
	BinaryTreeSize(root->_right);
	return size;

}

1.4二叉树第k层节点个数

// 二叉树第k层节点个数

int BinaryTreeLevelKSize(BTNode* root, int k);

cpp 复制代码
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);

}

1.5 二叉树查找值为x的节点

// 二叉树查找值为x的节点

BTNode* BinaryTreeFind(BTNode* root, BTDataType x);

cpp 复制代码
BTNode* BinaryTreeFind(BTNode* root, BTDataType x)
{
	if (root == NULL)
		return NULL;
	if (root->_data == x)
		return root;
	BTNode* left = BinaryTreeFind(root->_left, x);
	if (left)
		return left;
	BTNode*right = BinaryTreeFind(root->_right, x);
	if (right)
		return right;
}

1.6二叉树前序遍历

// 二叉树前序遍历

void BinaryTreePrevOrder(BTNode* root);

cpp 复制代码
void BinaryTreePrevOrder(BTNode* root)
{
	if (root == NULL)
		return;
	printf("%c ", root->_data);
	BinaryTreePrevOrder(root->_left);
	BinaryTreePrevOrder(root->_right);
}

1.7二叉树中序遍历

// 二叉树中序遍历

void BinaryTreeInOrder(BTNode* root);

cpp 复制代码
void BinaryTreeInOrder(BTNode* root)
{
	BinaryTreeInOrder(root->_left);
	printf("%c ", root->_data);
	BinaryTreeInOrder(root->_right);
	
}

1.8二叉树后序遍历

// 二叉树后序遍历

void BinaryTreePostOrder(BTNode* root);

cpp 复制代码
void BinaryTreePostOrder(BTNode* root)
{
	BinaryTreePostOrder(root->_left);
	BinaryTreePostOrder(root->_right);
	printf("%c ", root->_data);
}

1.9层序遍历

// 层序遍历

void BinaryTreeLevelOrder(BTNode* root);

cpp 复制代码
void BinaryTreeLevelOrder(BTNode* root)
{
	
	Queue q;
	QueueInit(&q);
	if (root)
		QueuePush(&q, root);
	while (!QueueEmpty(&q))
	{
		BTNode* node=QueueFrontdata(&q);
		printf("%c ", node->_data);
		QueuePop(&q);
		if (node->_left)
		{
			QueuePush(&q, node->_left);
		}
		if (node->_right)
		{
			QueuePush(&q, node->_right);
		}
	}

}

1.10判断二叉树是否是完全二叉树

// 判断二叉树是否是完全二叉树

int BinaryTreeComplete(BTNode* root);

cpp 复制代码
int BinaryTreeComplete(BTNode* root)
{
	Queue q;
	QueueInit(&q);
	if (root)
		QueuePush(&q, root);

	while (!QueueEmpty(&q))
	{
		BTNode* tmp= QueueFrontdata(&q);
		QueuePop(&q);
		if (tmp == NULL)
			break;
		QueuePush(&q, tmp->_left);
		QueuePush(&q, tmp->_right);

	}
	while (!QueueEmpty(&q))
	{
		if (QueueFrontdata(&q) != NULL)
		{
			QueueDestory(&q);
			return false;
		}
		QueuePop(&q);
	}

	QueueDestory(&q);
	return true;
}

1.11 二叉树叶子节点个数

// 二叉树叶子节点个数

int BinaryTreeLeafSize(BTNode* root);

cpp 复制代码
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);

}

结尾:今天的分享到此结束,喜欢的朋友如果感觉有帮助可以点赞三连支持,咱们共同进步!

相关推荐
hansang_IR20 分钟前
【题解】洛谷 P4286 [SHOI2008] 安全的航线 [递归分治]
c++·数学·算法·dfs·题解·向量·点积
乐迪信息20 分钟前
乐迪信息:AI摄像机在智慧煤矿人员安全与行为识别中的技术应用
大数据·人工智能·算法·安全·视觉检测
GanGuaGua29 分钟前
Linux系统:线程的互斥和安全
linux·运维·服务器·c语言·c++·安全
多恩Stone1 小时前
【3DV 进阶-2】Hunyuan3D2.1 训练代码详细理解下-数据读取流程
人工智能·python·算法·3d·aigc
dragoooon341 小时前
[数据结构——lesson5.1链表的应用]
数据结构·链表
惯导马工2 小时前
【论文导读】IDOL: Inertial Deep Orientation-Estimation and Localization
深度学习·算法
老姜洛克2 小时前
自然语言处理(NLP)之n-gram从原理到实战
算法·nlp
CoovallyAIHub3 小时前
基于YOLO集成模型的无人机多光谱风电部件缺陷检测
深度学习·算法·计算机视觉
CoovallyAIHub3 小时前
几十个像素的小目标,为何难倒无人机?LCW-YOLO让无人机小目标检测不再卡顿
深度学习·算法·计算机视觉
怀旧,3 小时前
【C++】19. 封装红⿊树实现set和map
linux·c++·算法