二叉树的遍历题型

二叉树的基础内容:二叉树基础总结-CSDN博客

题目:美国血统

题目描述

农夫约翰非常认真地对待他的奶牛们的血统。然而他不是一个真正优秀的记帐员。他把他的奶牛 们的家谱作成二叉树,并且把二叉树以更线性的“树的中序遍历”和“树的前序遍历”的符号加以记录而 不是用图形的方法。

你的任务是在被给予奶牛家谱的“树中序遍历”和“树前序遍历”的符号后,创建奶牛家谱的“树的 后序遍历”的符号。每一头奶牛的姓名被译为一个唯一的字母。(你可能已经知道你可以在知道树的两 种遍历以后可以经常地重建这棵树。)显然,这里的树不会有多于 2626 个的顶点。

这是在样例输入和样例输出中的树的图形表达方式:

         C
         /  \
        /  \
       B    G
      / \  /
       A   D  H
        / \
       E   F

附注:

  • 树的中序遍历是按照左子树,根,右子树的顺序访问节点;
  • 树的前序遍历是按照根,左子树,右子树的顺序访问节点;
  • 树的后序遍历是按照左子树,右子树,根的顺序访问节点。

输入格式

第一行一个字符串,表示该树的中序遍历。

第二行一个字符串,表示该树的前序遍历。

输出格式

单独的一行表示该树的后序遍历。

输入输出样例

输入 #1

ABEDFCHG
CBADEFGH 

输出 #1

AEFDBHGC

代码实现

代码解析

头文件是c++万能头

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

 全局定义

//p为前序遍历的字符串,in为中序遍历的字符串
string p, in;

string的作用: 

string 的作用是表示字符串类型,它是 C++ 标准库中的一个类,用于存储和操作字符序列。在这段代码中,string 类型被用于两个变量 p 和 in,分别表示模式字符串和输入字符串。

代码的主要逻辑是:根据模式字符串 p 的结构,在输入字符串 in 中找到相应的字符序列,并按照某种顺序打印出来。

string 提供了多种方法和成员函数,用于操作字符串,例如:

  • substr(pos, len):从位置 pos 开始提取长度为 len 的子字符串。
  • find(char):查找第一个出现的指定字符的位置。
  • erase(pos, len):从位置 pos 开始删除长度为 len 的字符序列。

在 fun 函数中,string 的这些方法和成员函数被用来分割模式字符串和输入字符串,并在找到相应的字符后打印出来。

 调用函数

void fun(string p, string in)
{
	if (p.empty())return;//判断字符串是否已经遍历完了
	char root = p[0];//由前序遍历的性质可知第一个字符串为根节点
	int g = in.find(root);//由中序遍历的性质可知,根节点的左边全是左子树,右边全是右子树
	p.erase(p.begin());//将前序遍历的第一个根节点删除
	string lp = p.substr(0, g);//substr的作用前文说明了
	string rp = p.substr(g);
	string lin = in.substr(0, g);
	string rin = in.substr(g + 1);
    //树的后序遍历是按照左子树,右子树,根的顺序访问节点
	fun(lp, lin);//左子树的递归
	fun(rp, rin);//右子树的递归
	printf("%c", root);
}

全部代码: 

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

string p, in;

void fun(string p, string in)
{
	if (p.empty())return;
	char root = p[0];
	int g = in.find(root);
	p.erase(p.begin());
	string lp = p.substr(0, g);
	string rp = p.substr(g);
	string lin = in.substr(0, g);
	string rin = in.substr(g + 1);
	fun(lp, lin);
	fun(rp, rin);
	printf("%c", root);
}
int main()
{
	cin >> in >> p;
	fun(p, in);

	return 0;
}

题目:求先序排列

题目描述

给出一棵二叉树的中序与后序排列。求出它的先序排列。(约定树结点用不同的大写字母表示,且二叉树的节点个数 ≤8)。

输入格式

共两行,均为大写字母组成的字符串,表示一棵二叉树的中序与后序排列。

输出格式

共一行一个字符串,表示一棵二叉树的先序。

输入输出样例

输入 #1

BADC
BDCA

输出 #1

ABCD

 代码实现(思路是一样的)

代码解析:

头文件是c++万能头

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

全局定义

//p表示后序,in表示中序
string p, inor;

调用函数

void fun(string p, string inor) {
	if (p.empty())return;
	char root = p[p.size() - 1];//根节点
	int g = inor.find(root);
	string lin = inor.substr(0, g);
	string rin = inor.substr(g + 1);
	string lp = p.substr(0, g);
	string rp = p.substr(g, p.size() - g - 1);
	cout << root;
	fun(lp,lin);
	fun(rp,rin);
}

全部代码:
#include<bits/stdc++.h>
using namespace std;
string p, inor;//p表示后序,in表示中序
void fun(string p, string inor) {
	if (p.empty())return;
	char root = p[p.size() - 1];//根节点
	int g = inor.find(root);
//	p.erase(p[p.size() - 1]);
	string lin = inor.substr(0, g);
	string rin = inor.substr(g + 1);
	string lp = p.substr(0, g);
	string rp = p.substr(g, p.size() - g - 1);
	cout << root;
	fun(lp,lin);
	fun(rp,rin);
}

int main()
{
	cin >> inor >> p;
	fun(p, inor);
	printf("\n");
	return 0;
}

  • 12
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值