二叉树的实现(纯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);

}

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

相关推荐
励志要当大牛的小白菜2 小时前
ART配对软件使用
开发语言·c++·qt·算法
qq_513970442 小时前
力扣 hot100 Day56
算法·leetcode
PAK向日葵3 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试
爱装代码的小瓶子5 小时前
数据结构之队列(C语言)
c语言·开发语言·数据结构
爱喝矿泉水的猛男5 小时前
非定长滑动窗口(持续更新)
算法·leetcode·职场和发展
YuTaoShao5 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
YouQian7726 小时前
Traffic Lights set的使用
算法
快乐飒男6 小时前
哈希表(c语言)
c语言·哈希算法·散列表
go54631584657 小时前
基于深度学习的食管癌右喉返神经旁淋巴结预测系统研究
图像处理·人工智能·深度学习·神经网络·算法
aramae8 小时前
大话数据结构之<队列>
c语言·开发语言·数据结构·算法