7-5 先序序列+中序序列建立二叉树

先序序列+中序序列建立二叉树

输入样例:

第一行输入序列长度n,第二行输入n个字符表示二叉树先序遍历的序列,第三行输入n个字符表示二叉树中序遍历的序列

9
ABDGHCEFI
GDHBAECIF

输出样例:

输出二叉树后序遍历的序列。

GHDBEIFCA

代码示例如下:

#include<bits/stdc++.h>
using namespace std;

/*
	9
	ABDGHCEFI
	GDHBAECIF

	结果:GHDBEIFCA
*/

struct treeNode
{
	char data;
	treeNode* left;			//左孩子
	treeNode* right;		//右孩子
};
// 前序:中左右
// 中序:左中右
void CreateTree_pre_middle(treeNode* &node, string pre_order, string in_order, int pre1, int pre2, int middle1, int middle2)
{
	//前提条件
	if (pre2 >= pre1 && middle2 >= middle1)
	{
		node = new treeNode();
		//第一个是根节点
		node->data = pre_order[pre1];
		//初始化
		node->left = node->right = nullptr;

		//在中序中找到根节点 i 的位置
		int i;
		for (i = middle1; i <= middle2; ++i)
		{
			if (in_order[i] == node->data)
				break;
		}
		//创建左子树和右子树
		//注意这里是:node->left,node->right,不是node
		CreateTree_pre_middle(node->left, pre_order, in_order, pre1 + 1, pre1 + i - middle1, middle1, i - 1);
		CreateTree_pre_middle(node->right, pre_order, in_order, pre1 + i - middle1 + 1, pre2, i + 1, middle2);
	}
}
void post_view(treeNode* node)
{
	if (node == nullptr)	return;
	post_view(node->left);
	post_view(node->right);
	cout << node->data;
}

int main()
{
	int n;
	cin >> n;
	string pre_order, in_order;
	cin >> pre_order >> in_order;
	treeNode* root;
	CreateTree_pre_middle(root, pre_order, in_order, 0, n - 1, 0, n - 1);
	post_view(root);

	return 0;
}

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

_我想睡觉

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

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

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

打赏作者

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

抵扣说明:

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

余额充值