iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >刷题系列 - 中序和后序遍历队列,构造对应二叉树;
  • 211
分享到

刷题系列 - 中序和后序遍历队列,构造对应二叉树;

2023-06-02 00:06:21 211人浏览 安东尼
摘要

假期继续刷题,也没有别的什么事情可以干。这个题是给出中序和后序遍历队列,构造对应二叉树;题目很简单,如下图,给出两个遍历队列,构成二叉树,这里假定没有重复点。 想了好几天,真是惭愧,因为一直想一次遍历就完成构造,最后发现不行;然后

假期继续刷题,也没有别的什么事情可以干。

这个题是给出中序和后序遍历队列,构造对应二叉树;题目很简单,如下图,给出两个遍历队列,构成二叉树,这里假定没有重复点。

 刷题系列 - 中序和后序遍历队列,构造对应二叉树;

想了好几天,真是惭愧,因为一直想一次遍历就完成构造,最后发现不行;然后就硬搞出一个多重循环的遍历方法,虽然可行,但是提交后提示耗时超过限制。最后还是用递归实现的。

其实原理很简单,对于后续遍历队列,最后一个值就是整个二叉树的根节点;而这个根节点去掉后,可以把二叉树分成左右两个树,在中序队列中,按照这个根节点来拆分出可以得到左右队列,分布对应左边树和右边树的所有点。而且其实后序队列也是按照左右树节点划分的,只要知道左右树的节点数量,来划分就可以了,这个可以从中序队列划分结果获得。反复同理,再划分出来左右树继续划分,可以得到叶子节点,或者空序列;这样就完成树的构成。

代码如下:

# Definition for a binary tree node.# class TreeNode:#     def __init__(self, x):#         self.val = x#         self.left = None#         self.right = Noneclass Solution:    def buildTree(self, inorder: List[int], postorder: List[int]) -> TreeNode:        if inorder == []:            return None        else:            if len(inorder) == 1:                return TreeNode(inorder[0])            else:                RootVal = postorder[-1]                currentNode = TreeNode(RootVal)                inorderLeft = inorder[:inorder.index(RootVal)]                inorderRight = inorder[inorder.index(RootVal)+1:]                postorder.pop()                postorderLeft = postorder[:len(inorderLeft)]                postorderRight = postorder[-len(inorderRight):]                 currentNode.left = self.buildTree(inorderLeft,postorderLeft)                currentNode.right = self.buildTree(inorderRight,postorderRight)                return currentNode

  

--结束END--

本文标题: 刷题系列 - 中序和后序遍历队列,构造对应二叉树;

本文链接: https://www.lsjlt.com/news/228225.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 刷题系列 - 中序和后序遍历队列,构造对应二叉树;
    假期继续刷题,也没有别的什么事情可以干。这个题是给出中序和后序遍历队列,构造对应二叉树;题目很简单,如下图,给出两个遍历队列,构成二叉树,这里假定没有重复点。 想了好几天,真是惭愧,因为一直想一次遍历就完成构造,最后发现不行;然后...
    99+
    2023-06-02
  • 刷题系列 - 给出前序和中序遍历队列,构造对应二叉树
    既然中序和后序队列构成二叉树写了,就把前序和中序一做吧。原理其实也很简单,前序队列第一个点就是根节点,再中序队列里面这个根节点可以分出左右两个树的两个中序队列,然后可以按照左右树的节点数量,再前序节点里面分出对应两组前序队列;然后反复递归即...
    99+
    2023-06-02
  • 刷题系列 - 序列化和反序列化一个二叉树
    序列化和反序列化一个二叉树,是很开放的一题,就是给出一个二叉树,用序列化方法生成一个字符串;然后用反序列化方法把这个字符串生成原来二叉树。这个在编程时候各个类型一般都有序列化的,用于存储。这里面要用到python中list转化字符串方法 &...
    99+
    2023-06-02
  • 刷题系列 - Python用非递归实现二叉树后续遍历
    顺便把Python用非递归实现二叉树后续遍历也写了。其实前序中序和后续都是针对父节点说的。比如下面这个最简单二叉树。前序就是ABC,父节点A在前中序就是BAC,父节点A在中间后序就是BCA,父节点A在最后无论多复杂二叉树,基本都是同样遍历流...
    99+
    2023-06-02
  • 刷题系列 - Python中怎么通过非递归实现二叉树前序遍历
    这期内容当中小编将会给大家带来有关刷题系列 - Python中怎么通过非递归实现二叉树前序遍历,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。二叉树前序遍历(Binary Tree Preorder Tra...
    99+
    2023-06-02
  • C++实现LeetCode(106.由中序和后序遍历建立二叉树)
    [LeetCode] 106. Construct Binary Tree from Inorder and Postorder Traversal 由中序和后序遍历建立二叉树 Gi...
    99+
    2024-04-02
  • C语言数据结构二叉树先序、中序、后序及层次四种遍历
    目录一、图示展示(1)先序遍历(2)中序遍历(3)后序遍历(4)层次遍历(5)口诀二、代码展示一、图示展示 (1)先序遍历 先序遍历可以想象为,一个小人从一棵二叉树根节点为起点,沿着...
    99+
    2024-04-02
  • Java数据结构最清晰图解二叉树前中后序遍历
    目录一,前言二,树①概念②树的基础概念三,二叉树①概念②两种特殊的二叉树③二叉树的性质四,二叉树遍历①二叉树的遍历②前序遍历③中序遍历④后序遍历五,完整代码一,前言 二叉树是数据结构...
    99+
    2024-04-02
  • Java 数据结构中二叉树前中后序遍历非递归的具体实现详解
    目录一、前序遍历1.题目描述2.输入输出示例3.解题思路4.代码实现二、中序遍历1.题目描述2.输入输出示例3.解题思路4.代码实现三、后序遍历1.题目描述2.输入输出示例3.解题思...
    99+
    2024-04-02
  • 如何进行Java 数据结构中二叉树前中后序遍历非递归的具体实现
    本篇文章为大家展示了如何进行Java 数据结构中二叉树前中后序遍历非递归的具体实现,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、前序遍历1.题目描述给你二叉树的根节点 root ,返回它节点值的...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作