[二叉树] 二叉树的前中后三序遍历#知二求一

标题:[二叉树] 二叉树的前中后三序遍历#知二求一

@水墨不写bug

(图片来源于网络) 


 正文开始:

        其实这一类题就是考察对二叉树的结构理解,此类题目的二叉树一般通过数组传入,我们只需根据二叉树的就够特点对数组进行分区即可,其实这也是一个看递归的一个全新的视角,即将数组递归的分为 “根” “左区间” “右区间”,这一过程生动诠释了递归的特色。

        对于传入的数组,将其分为根,左区间,右区间。其中,左区间代表左子树,右区间代表右子树。

从整体上来说:

前序遍历分为:根——左区间——右区间;(根——左区间——右区间)

中序遍历分为:左区间——根——右区间;(左子树——根——右子树)

后序遍历分为:左区间——右区间——根;(左子树——右子树——根)

(一)知前序中序求后序(前+中->后)

        (1)已知某二叉树的前序遍历序列为5 7 4 9 6 2 1,中序遍历序列为4 7 5 6 9 1 2,则其后序遍历序列为( )

思路:

抓住前序三序遍历的特点:

        前序遍历的首元素就是二叉树的根;

        中序遍历的根的左右区间分别就是左子树和右子树;

        后序遍历的最后一个元素就是二叉树的根;

总结:

        前序和后序是用来获得根的,中序是用来根据根的相对位置来分别区分出左右区间(左右字数的);

 

接下来再通过解决例题(1)来验证一下结论:

        通过前序遍历找到子树的根,在中序遍历中找到根的位置,然后确定根左右子树的区间,即根的左侧为左子树中所有节点,根的右侧为右子树中所有节点。

故:根为: 5

        5的左子树:4 7   5的右子树: 6 9  1  2

        5的左子树的根为: 7  5的右子树的根为:9

        7的左子树: 4 7的右:空  9的左子树:6  9的右子树:2

故这棵树的结构为:

(二)知前序后序求中序(前+后->中)

        仅通过二叉树的前序遍历和后序遍历,我们不能唯一地确定一个二叉树的中序遍历结果,因为存在多种可能的二叉树结构满足相同的前序和后序遍历结果。

        前序遍历的顺序是:根节点 -> 左子树 -> 右子树
        后序遍历的顺序是:左子树 -> 右子树 -> 根节点

        但是,没有中序遍历(左子树 -> 根节点 -> 右子树)的信息,我们就无法准确地知道左子树和右子树各包含哪些节点,特别是当节点值可以重复时。

        然而,如果我们知道二叉树是满二叉树(每个节点都有两个子节点)或者是完全二叉树(除最后一层外,其他层都是满的,并且最后一层的节点都靠左排列),并且节点值不重复,那么在某些特定情况下,我们可能可以推断出中序遍历的结果。但这不是一般情况下的解决方案。

        对于一般情况,如果我们需要从前序和后序遍历中恢复二叉树(或中序遍历),我们需要额外的信息或使用更复杂的算法,如基于树的重建算法,但这通常涉及到递归的猜测和验证过程,且不一定总是可行的。

        所以,简单地说,仅通过前序和后序遍历,我们不能直接求出中序遍历的结果。

如果你对这一结论感兴趣,可以参考这篇文章来深入探究:

【数据结构与算法】"先序+后序"能否确定二叉树结构?一个简单的判别法 - 知乎 (zhihu.com)

(三)知中序后序求前序(中+后->前)

        已知某二叉树的中序遍历序列为JGDHKBAELIMCF,后序遍历序列为JGKHDBLMIEFCA,则其前序遍历序列为( )

        由后序遍历确定子树的根,后序遍历从后向前看,最后一个元素为根,和前序遍历刚好相反,从后向前看后序遍历,应该是根,右,左,根据中序遍历确定子树的左右区间

故:根为: A

        A的左子树:JGDHKB       A的右子树:ELIMCF

        A的左子树的根:B            A的右子树的根:C

        B的左子树:JGDHK  B的右子树:空  C的左子树:ELIM C的右子树:F

        B的左子树的根:D         C的左子树根:E

        D的左子树的根:G   D的右子树的根:H       E的右子树的根:I

故树的结构为:

 


完~

未经作者同意禁止转载 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/660402.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Docker: 如何不新建容器 修改运行容器的端口

目录 一、修改容器的映射端口 二、解决方案 三、方案 一、修改容器的映射端口 项目需求修改容器的映射端口 二、解决方案 停止需要修改的容器 修改hostconfig.json文件 重启docker 服务 启动修改容器 三、方案 目前正在运行的容器 宿主机的3000 端口 映射 容器…

程序员出路在哪?技术变迁与时代背景的双重挑战

在这个充满不确定性的时代,焦虑似乎成了每个人心中不可避免的情绪,准备好,我要开始贩卖焦虑了 。 最近,裁员的消息真的太多了,下面是我最近看到的裁员消息: 2024 年 3 月份,字节内部公开信曝光…

pip是的配置

1 疑惑 当你安装了python后打开cmd命令行输入pip发现运行不起来 疑惑了吧不是说python有内置的吗,怎么运行不起来,很简单没有配置环境变量所以运行不了 2 如何打开环境变量配置 打开电脑的设置 找到关于点开高级系统设置 点开环境变量 点开后有系统变…

LLM大语言模型原理、发展历程、训练方法、应用场景和未来趋势

LLM,全称Large Language Model,即大型语言模型。LLM是一种强大的人工智能算法,它通过训练大量文本数据,学习语言的语法、语义和上下文信息,从而能够对自然语言文本进行建模。这种模型在自然语言处理(NLP&am…

windows11家庭版开启Hyper-v

前提:如果在控制面板中-->程序和功能-->启用和关闭windows功能-->没有Hyper-v 1.什么是Hyper-v? Hyper-v分为两个部分:底层的虚拟机平台、上层的虚拟机管理软件 2.Hyper-v安装 2.1新建hyper.cmd文件,写入下面的内容&…

变电站自动化控制系统应用案例分析

变电站自动化控制系统介绍 变电站自动化控制系统用于大中型企业变电站项目,这类企业变压器多,日耗电量大。把多个变压器集中到一个电器平台上,集中管理分析,优化厂区用电管理,从而达到集中控制、集中分析、集中管理的…

设计模式之建造者模式BuilderPattern(七)

一、建造者模式 建造者模式(Builder Pattern)使用多个简单的对象一步一步构建成一个复杂的对象。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。 二、代码实例 1、OrderItem类 Data:这是Lombok中提供的Ge…

form1弹出子窗体form2,拖动子窗体判断是否离开父窗体区域,含源码(学习笔记)

一、效果(进入和离开) 子窗体到达父窗体边缘时变色。 二、代码分析 判断父窗体的目的,可以控制子窗体要随父窗体走。上面代码需要加以处理。 如:this.Location new Point(parentPoint.X distanceFromEdge, this.Location.Ydis…

MySQL中怎么存放一条记录

2.2.1. MySQL中一行记录是怎么存储的? MySQL的数据存储在那个文件? 每创建一个 database(数据库)都会在 /var/lib/mysql/ 目录里面创建一个以 database 为名的目录,然后保存表结构和表数据的文件都会存放在这个目录里…

Spark SQL编程初级实践

参考链接 Spark编程: Spark SQL基本操作 2020.11.01_df.agg("age"->"avg")-CSDN博客 RDD编程初级实践-CSDN博客 Spark和Hadoop的安装-CSDN博客 1. Spark SQL基本操作 { "id":1 , "name":" Ella" , "age":…

MySql-日期分组

一、分别统计各时间各类型数据条数 数据库的 request_time字段 数据类型:timestamp 默认值:CURRENT_TIMESTAMP 例子: 2024-01-26 08:25:48 原数据: 1、将数据按照日期(年月日)形式输出 按照request_…

RISC和CISC含义及其区别

一、含义 RISC(Reduced Instruction Set Computer)和CISC(Complex Instruction Set Computer)是两种不同类型的计算机架构。它们的区别主要在于指令集和执行时间。 RISC架构通常采用简化的指令集,每条指令执行的操作非…