二叉树创建与销毁操作详解

目录

一、通过前序遍历的数组构建二叉树

1.1 递归思路

1.2 递归分支图

1.3 递归栈帧图

1.4 C语言实现

二、二叉树的销毁

2.1 递归思路

2.2 递归分支图

2.3 递归栈帧图

2.4 C语言实现


一、通过前序遍历的数组构建二叉树

牛客网链接:二叉树遍历_牛客题霸_牛客网
以"ABD##E#H##CF##G##"为例;“#”代表空树

1.1 递归思路

考虑特殊情况:

  1. 如果为#,则返回NULL
  2. 如果不为#,则创建一个结点

考虑一般情况:

  1. 前序遍历先构建左数再构建右树

  2. 递归将每个结点都看作是根节点来构建二叉树

1.2 递归分支图

1.3 递归栈帧图

1.4 C语言实现

注意事项:递归会创建栈帧,栈帧间的变量值互不影响,所以要想每次调用函数都要改变数组的下标,就要使用指针的方法去修改变量。

BTNode* CreateTree(char* a, int* pi)
{
	if (a[*pi] == '#')
	{
		(*pi)++;
		return NULL;
	}
	BTNode* root = (BTNode*)malloc(sizeof(BTNode));
	if (root == NULL)
	{
		perror("malloc");
		exit(1);
	}
	root->data = a[(*pi)++];
	root->left = CreateTree(a, pi);
	root->right = CreateTree(a, pi);
	return root;
}

二、二叉树的销毁

2.1 递归思路

不可以用循环原因:销毁根节点后无法找到左右子树的结点。即便保存了左右子树的结点后无法找到下一层的结点。

使用递归的特性:从叶子节点开始释放空间,从而达到销毁的目的

2.2 递归分支图

2.3 递归栈帧图

2.4 C语言实现

void BinaryTreeDestory(BTNode* root)
{
	//判空
	if (root == NULL)
	{
		return NULL;
	}
	//释放左子树
	BinaryTreeDestory(root->left);
	//释放右子树
	BinaryTreeDestory(root->right);
	//释放本身结点
	free(root);
}

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值