根据二叉树先序遍历和中序遍历构建二叉树

article/2025/9/1 18:13:15

前方有一个人在等着你,你只管勇敢的向前走


采用递归分治的思想,将一个大问题划分成子问题,

对于本题,根据二叉树先序遍历和中序遍历构建二叉树,思路:

  • 我们可以求得根节点左子树的先序和中序序列,以及右子树的先序和中序序列
  • 此问题变成了根据左子树的先序和序列构建左子树的二叉树,根据右子树的先序和中序序列构建右子树的二叉树问题得以分解成子问题

在这里插入图片描述
​​
令先序序列和中序序列在数组中连续存放。

设先序序列第一个字母的数组中的位置为Xb,最后一个字母的数组中的位置为Xe,中序序列第一个字母的位置为Zb,最后一个字母的位置为Ze

从中序序列中,能找到一个节点将当前二叉树分为左子树与右子树,设此节点位于中序序列的k位置

左子树节点个数num=k-Zb

所以左子树的先序序列区间[Xb+1,Xb+num];中序区间[Zb,k-1]

右子树的先序区间[Xb+num+1,Xe],中序区间[k+1,Ze]


​​在这里插入图片描述

而递归结束的条件是什么呢?

我们可以考虑一下临界条件,即递归的最底层,当先序序列只剩一个节点D时,需要构造该节点,可当先序序列没有了的时候,说明二叉树就到尽头了,所以当先序序列的长度小于等于0时,为递归边界。

代码思路:

定义一个node类型的结构体;

struct node
{char data;node * lchild;node * rchild;
};

步骤一:构造一个创造节点的createNode函数,函数里的参数即为先序序列区间,中序序列区间,createNode(Xb,Xe,Zb,Ze); 返回值类型为指向 node型的指针。

1.判断是否到达递归边界,到达边界了就返回一个 NULL,即二叉树到达叶子的子节点(叶子节点是不存在子节点的,我就是想表示该节点不存在,不需要构造,要返回上一层,返回到叶子节点)

即判断先序区间长度是否小于等于0,即Xb是否小于等于Xe

2.没到达边界就构造节点


node *Node=new node;node->data=data;

3.在中序序列中找到将中序序列分为左子树和右子树的节点位置k

for (int i = Zb; i <Ze+1; i++){if (xianxu[Xb] == zhongxu[i]){k = i;break;}}

4.递归


Node->lchild=create(Xb,Xe,Zb,Ze);Node->rchild=create(Xb,Xe,Zb,Ze)

代码

//根据先序中序,构造后序
#include <iostream>
#include <string>
using namespace std;
struct node
{char data;node * lchild;node * rchild;
};
node *createNode(int Xb, int Xe, int Zb, int Ze,string xianxu,string zhongxu);
void houxu(node *Node);int main()
{string xianxu;string zhongxu;while (cin >> xianxu) {cin >> zhongxu;int Xb, Xe, Zb, Ze;//Xb表示先序开始字符位置Xe表示先序结束字符位置 Zb表示中序开始字符位置,Ze表示中序结束字符位置Xb = Zb = 0;Xe = xianxu.length() - 1;Ze = zhongxu.length() - 1;node *Node = new node;Node = createNode(Xb, Xe, Zb, Ze, xianxu, zhongxu);houxu(Node);}system("pause");return 0;
}
node *createNode(int Xb, int Xe, int Zb, int Ze,string xianxu,string zhongxu)
{if(Xb >Xe)return NULL;node *Node = new node;Node->data = xianxu[Xb];int k=0;for (int i = Zb; i <Ze+1; i++){if (xianxu[Xb] == zhongxu[i]){k = i;break;}}Node->lchild = createNode(Xb + 1, Xb+k-Zb, Zb, k - 1, xianxu, zhongxu);Node->rchild = createNode(Xb+k-Zb + 1, Xe, k + 1, Ze, xianxu, zhongxu);return Node;}
void houxu(node *Node)
{if (Node == NULL)return;houxu(Node->lchild);houxu(Node->rchild);cout << Node->data;
}

http://chatgpt.dhexx.cn/article/pINf4Xsf.shtml

相关文章

二叉树前序、中序、后序遍历非递归写法的透彻解析

前言 在前两篇文章二叉树和二叉搜索树中已经涉及到了二叉树的三种遍历。递归写法&#xff0c;只要理解思想&#xff0c;几行代码。可是非递归写法却很不容易。这里特地总结下&#xff0c;透彻解析它们的非递归写法。其中&#xff0c;中序遍历的非递归写法最简单&#xff0c;后…

二叉树的后序遍历

二叉树文章系列&#xff1a; 二叉树的前序遍历二叉树的中序遍历二叉树的后序遍历二叉树的层序遍历二叉树的前序、中序、后序、层序遍历【解法完整版】 本文目录 一、解题思路&#xff1a;递归二、解题思路&#xff1a;迭代&#xff08;方法1&#xff09;三、解题思路&#xff…

C语言完整代码实现:二叉树的先序遍历、中序遍历、后序遍历

一、先序遍历原理 先序遍历就是&#xff1a;根、左、右&#xff0c;也就是先遍历根结点再遍历左结点最后再遍历右结点&#xff0c;注意&#xff1a;如果遍历到的结点不是叶子结点的话需要对该结点进行拆分&#xff0c;比如这棵二叉树&#xff1a; 先遍历A&#xff0c;然后是B&a…

数据结构——二叉树的先序遍历

二叉树的遍历分为 先序遍历&#xff0c;中序遍历&#xff0c;后序遍历&#xff0c;层次遍历 四种遍历。 这节要分享的是先序遍历 如图所示&#xff0c;这是一个普通的二叉树。他的先序遍历是&#xff1a;A B D E H C F G I J 为什么呢&#xff1f; 先序遍历的遍历规则是&am…

二叉树三种遍历顺序

三.二叉树的三种遍历方式 1.先序遍历&#xff1a;按照根节点->左子树->右子树的顺序访问二叉树 先序遍历&#xff1a;&#xff08;1&#xff09;访问根节点&#xff1b;&#xff08;2&#xff09;采用先序递归遍历左子树&#xff1b;&#xff08;3&#xff09;采用先序…

二叉树(Binary Tree):先序遍历、中序遍历、后序遍历和层次遍历

二叉树&#xff08;Binary Tree&#xff09;&#xff1a;先序遍历、中序遍历、后序遍历和层次遍历 树 Tree二叉树 Binary Tree先序遍历 Preorder Traversal中序遍历 Inoreder Traversal后序遍历 Postorder Traversal层次遍历 Level Traversal 树 Tree 根 Root&#xff1a;树顶部…

oracle awr监控报告,一个Oracle小白的AWR报告分析(一)

背景&#xff1a;某个类似准实时的数据分析系统&#xff0c;每15分钟从其他6个数据库中抽取五百张增量数据表&#xff0c;并进行15分钟粒度统计&#xff0c;同时有个前端门户进行查询。 该数据分析系统由数据抽取服务器、应用服务器、数据库服务器组成&#xff0c;全部为虚拟机…

oracle生成awr报告命令,Oracle AWR报告生成方法

1、登录Oracle程序所在的服务器&#xff0c;查找出awrrpt.sql文件所在位置 D:\oracle\product\10.2.0\db_1\RDBMS\ADMIN\awrrpt.sql 2、登录Oracle&#xff0c;以sysdba身份连接 3、执行命令 D:\oracle\product\10.2.0\db_1\RDBMS\ADMIN\awrrpt.sql 4、输入report_type报告类型…

oracle打印awr报告,oracle导出AWR报告步骤

1、进入数据库 sqlplus / as sysdba ps:如果出现用户密码错误&#xff0c; 计算机管理 > 组 > ora_dba组里的用户登陆操作系统&#xff0c;就可以无需输入用户和口令&#xff0c;直接以sysdba的身份连上数据库。 2、查看用户 show parameter db_name 3、开始压测后执行 e…

Oracle导出AWR报告

一、使用root用户登录Linux服务器 二、切换至oracle用户 执行命令&#xff1a;su – oracle&#xff0c;然后回车 三、使用管理员权限连接数据库 执行命令&#xff1a;sqlplus / as sysdba&#xff0c;然后回车 四、生成报告快照 执行脚本&#xff1a;exec DBMS_WORKLOAD_RE…

如何分析AWR 报告

Automatic Workload Repository是10g引入的一个重要组件。在里面存贮着近期一段时间内&#xff0c;默认是7天&#xff0c;数据库活动状态的详细信息。 AWR报告是对AWR视图进行查询而得到的一份自动生成的报告。可以通过下面的脚本手工得到一份AWR报告。 exec dbms_w…

oracle 取awr报告,Oracle生成awr报告

Oracle生成awr报告 达芬奇的梦 2018-04-22 21:28:32 Oracle 一、手工生成awr报告的方法 1、相应权限用户登录(sysdba)后,在$ORACLE_HOME/rdbms/admin 2、在sqlplus里执行@?/rdbms/admin/awrrpt.sql,按照提示操作。 3、生成AWR报告说明 单实例:@$ORACLE_HOME/rdbms/admin/aw…

Oracle SQL调优系列之AWR报告简介

文章目录 一、AWE报告生成步骤1.1 工具选择1.2 自动创建快照1.3 手工创建快照1.4 生成AWR报告 二、AWR报告分析2.1 AWR之DB Time2.2 AWR之load_profile2.3 AWR之efficiency percentages2.4 AWR之top 10 events2.5 AWR之SQL Statistics 一、AWE报告生成步骤 对于SQL调优&#x…

AWR报告解读

0 初步结论 ① 数据库CPU资源不够&#xff0c;CPU使用率较高&#xff0c;造成CPU等待时间较长&#xff0c;可适当提升CPU资源&#xff1b; ② 数据库I/O资源消耗不太大&#xff0c;不存在IO瓶颈&#xff1b; ③ 可适当调大SGA空间&#xff08;增加10G左右&#xff09;&#xf…

用sql统计vintage,滚动率,迁移率,逾期率

获取代码请移步&#xff1a;用sql统计vintage&#xff0c;滚动率&#xff0c;迁移率&#xff0c;逾期率

如何用R语言做Vintage分析

一、背景 Vintage一词源自葡萄酒业&#xff0c;意思是葡萄酒酿造年份。因为每年的天气、温度、湿度、病虫害等情况不同&#xff0c;而这些因素都会对葡萄酒的品质产生很大的影响&#xff0c;所以人们对葡萄酒以葡萄当年的采摘年份进行标识来加以品质区分。现在Vintage分析被广泛…

风控中必做的数据分析

大数据领域就没有不做数据分析的&#xff0c;大数据风控也不例外。 我的观点是风控和其他互联网业务都是互通的&#xff0c;本文介绍下风控中必做的数据分析&#xff0c;用以说明数据分析是一通百通的。 工欲善其事&#xff0c;必先利其器。先说下数据分析的工具。 分析工具…

Vintage、滚动率、迁移率的应用

更多风控建模、大数据分析等内容请关注公众号《bigdatafengkong》 BY 小石头 一、Vintage Vintage源于葡萄酒酿造&#xff0c;葡萄酒的品质会因葡萄生长的年份不同、气候不同而不同。Vintage分析是指评估不同年份的葡萄酒的品质随着窖藏时间的推移而发生的变化&#xff0c;并且…

窗口函数:vintage报表

0 前言 Vintage这个词原意是指酿造葡萄酒的酒窖。葡萄酒是讲究年份&#xff0c;哪年光景好&#xff0c;哪年光景不好&#xff0c;直接会影响到葡萄酒的品质。后来借用到信贷资产行业&#xff0c;指的是每个月贷款的资产质量情况&#xff0c;要直接跟每个相同时间段内的余额做比…

信贷风控中Vintage、滚动率、迁移率的理解

风控业务背景 信贷风险管理是一门艺术&#xff0c;更是一门科学。资产质量分析中常会涉及到三个理论&#xff1a; 账龄分析&#xff08;Vintage Analysis&#xff09;&#xff1a;用以分析账户成熟期、变化规律等。滚动率分析&#xff08;Roll Rate Analysis&#xff09;&#…