【LeetCode热题100】105. 从前序与中序遍历序列构造二叉树(二叉树)

一.题目要求

给定两个整数数组 preorder 和 inorder ,其中 preorder 是二叉树的先序遍历, inorder 是同一棵树的中序遍历,请构造二叉树并返回其根节点。

二.题目难度

中等

三.输入样例

示例 1:
在这里插入图片描述
输入: preorder = [3,9,20,15,7], inorder = [9,3,15,20,7]
输出: [3,9,20,null,null,15,7]

示例 2:
输入: preorder = [-1], inorder = [-1]
输出: [-1]

提示:

  • 1 <= preorder.length <= 3000
  • inorder.length == preorder.length
  • -3000 <= preorder[i], inorder[i] <= 3000
  • preorder 和 inorder 均 无重复 元素
  • inorder 均出现在 preorder
  • preorder 保证 为二叉树的前序遍历序列
  • inorder 保证 为二叉树的中序遍历序列

四.解题思路

没有思路 看GPT总结吧

五.代码实现

class Solution {
public:TreeNode* buildTree(vector<int>& preorder, vector<int>& inorder) {return buildTreeHelper(preorder, 0, preorder.size(), inorder, 0, inorder.size());}private:TreeNode* buildTreeHelper(vector<int>& preorder, int preStart, int preEnd, vector<int>& inorder, int inStart, int inEnd) {if (preStart >= preEnd || inStart >= inEnd) {return nullptr;}TreeNode* root = new TreeNode(preorder[preStart]);auto rootPos = find(inorder.begin() + inStart, inorder.begin() + inEnd, preorder[preStart]);int leftSize = rootPos - (inorder.begin() + inStart);root->left = buildTreeHelper(preorder, preStart + 1, preStart + 1 + leftSize, inorder, inStart, inStart + leftSize);root->right = buildTreeHelper(preorder, preStart + 1 + leftSize, preEnd, inorder, inStart + 1 + leftSize, inEnd);return root;}
};

六.题目总结

构造二叉树的问题可以通过递归的方法解决,核心思路是利用先序遍历和中序遍历的特性:

  • 先序遍历(preorder)的特点是每次遍历的第一个元素都是当前子树的根节点。
  • 中序遍历(inorder)的特点是根节点将树分为左子树和右子树,左子树的节点都在根节点的左边,右子树的节点都在根节点的右边。

解题步骤

  • 步骤 1: 确定根节点

从先序遍历的数组中获取第一个元素,这个元素是当前子树的根节点。

  • 步骤 2: 分割中序遍历数组

在中序遍历的数组中找到根节点的位置,这个位置将数组分为两部分:左子树的中序遍历和右子树的中序遍历。

  • 步骤 3: 分割先序遍历数组

利用中序遍历中左子树的节点数,可以确定先序遍历数组中左子树和右子树的分界线。
第一个元素后面紧跟着的是左子树的先序遍历,接着是右子树的先序遍历。

  • 步骤 4: 递归构建子树

使用步骤 2 和步骤 3 中确定的左右子树的先序遍历和中序遍历数组,递归地构建左子树和右子树。

  • 步骤 5: 返回根节点

将构建好的左右子树分别连接到根节点的左右指针上,然后返回根节点。

示例
假设我们有以下先序遍历和中序遍历的数组:

  • preorder = [3,9,20,15,7]
  • inorder = [9,3,15,20,7]

先序遍历的第一个元素是3,所以3是根节点。
在中序遍历数组中找到3,它将数组分为两部分:

  • [9]是左子树的中序遍历,[15,20,7]是右子树的中序遍历。

由于左子树在中序遍历中有1个节点,我们知道先序遍历数组中第一个元素之后的一个元素(9)是左子树的先序遍历;剩下的[20,15,7]是右子树的先序遍历。

  • 对于左子树,先序遍历和中序遍历都只有一个元素[9],这意味着左子树只有一个节点9。

  • 对于右子树,我们重复上述过程,先序遍历[20,15,7]和中序遍历[15,20,7],可以构建出右子树。

  • 将构建好的左右子树连接到根节点3上。

通过这个过程,我们能够逐步构建出整棵树。

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

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

相关文章

政安晨:【Keras机器学习实践要点】(六)—— 使用内置方法进行训练和评估

政安晨的个人主页&#xff1a;政安晨 欢迎 &#x1f44d;点赞✍评论⭐收藏 收录专栏: TensorFlow与Keras实战演绎机器学习 希望政安晨的博客能够对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff01; 本文涵盖使用内置 API 进行训练和验证&#…

【leetcode】双“指针”

标题&#xff1a;【leetcode】双指针 水墨不写bug 我认为 讲清楚为什么要用双指针 比讲怎么用双指针更重要&#xff01; &#xff08;一&#xff09;快乐数 编写一个算法来判断一个数 n 是不是快乐数。 「快乐数」 定义为&#xff1a; 对于一个正整数&#xff0c;每一次将该数…

JAVA面试大全之JVM和调优篇

目录 1、类加载机制 1.1、类加载的生命周期&#xff1f; 1.2、类加载器的层次? 1.3、Class.forName()和ClassLoader.loadClass()区别? 1.4、JVM有哪些类加载机制&#xff1f; 2、内存结构 2.1、说说JVM内存整体的结构&#xff1f;线程私有还是共享的&#xff1f; 2.2…

布隆过滤器详讲

本文旨在讲解布隆过滤器的原理以及实现方式&#xff0c;希望通过本文能使读者对布隆过滤器有一定的认识&#xff01; 一、布隆过滤器的引入 在讲解布隆过滤器之前&#xff0c;我们还是先提及一下前面讲的位图行&#xff0c;位图可以处理大量的数据&#xff0c;广泛用于查找等…

【检索稳定|火爆征稿中】2024年企业管理与数字化经济国际学术会议(ICBMDE 2024)

【检索稳定|火爆征稿中】2024年企业管理与数字化经济国际学术会议&#xff08;ICBMDE 2024&#xff09; 2024 International Conference on Business Management and Digital Economy&#xff08;ICBMDE 2024&#xff09; ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~…

小米HyperOS 澎湃os机型免答题 免社区等级 秒接bl锁操作步骤解析

小米机型解锁bl 绕过社区等级5才可以解锁的限制的教程_没有五级社区怎么解锁bl-CSDN博客 上次解析了小米有些出厂不是HyperOS系统的机型绕社区等级接bl锁的操作。目前有更新出厂为HyperOS系统的机型免社区登录等级限制 免答题解锁bl的操作。而且有网友在米14 平板6sp k70这些新…

报错there is no HDFS_NAMENODE_USER defined

在Hadoop安装目录下找到sbin文件夹&#xff0c;修改里面的四个文件 1、对于start-dfs.sh和stop-dfs.sh文件&#xff0c;添加下列参数&#xff1a; HDFS_DATANODE_USERroot HDFS_DATANODE_SECURE_USERhdfs HDFS_NAMENODE_USERroot HDFS_SECONDARYNAMENODE_USERroot 2、对于st…

什么是物联网监控平台?部署物联网平台有什么作用?

随着物联网技术的飞速发展&#xff0c;越来越多的企业开始关注并投入到这一领域。物联网监控平台作为连接物理世界与数字世界的桥梁&#xff0c;正逐渐成为企业数字化转型的关键组件。今天&#xff0c;我们将深入探讨物联网监控平台的定义、部署物联网平台的作用&#xff0c;以…

OSG编程指南<二十一>:OSG视图与相机视点更新设置及OSG宽屏变形

1、概述 什么是视图?在《OpenGL 编程指南》中有下面的比喻,从笔者开始学习图形学就影响深刻,相信对读者学习场景管理也会非常有帮助。 产生目标场景视图的变换过程类似于用相机进行拍照,主要有如下的步骤: (1)把照相机固定在三脚架上,让它对准场景(视图变换)。 (2)…

实测梳理一下kafka分区分组的作用

清空topickafka-topics.sh --bootstrap-server localhost:9092 --delete --topic second创建分区kafka-topics.sh --create --bootstrap-server localhost:9092 --replication-factor 1 --partitions 3 --topic second发kafka-console-producer.sh --bootstrap-server localhos…

方格分割(蓝桥杯)

文章目录 方格分割题目描述答案&#xff1a;509思路dfs 方格分割 题目描述 本题为填空题&#xff0c;只需要算出结果后&#xff0c;在代码中使用输出语句将所填结果输出即可。 6x6的方格&#xff0c;沿着格子的边线剪开成两部分。 要求这两部分的形状完全相同。 如下就是三…

[Linux_IMX6ULL驱动开发]-基础驱动

驱动的含义 如何理解嵌入式的驱动呢&#xff0c;我个人认为&#xff0c;驱动就是嵌入式上层应用操控底层硬件的桥梁。因为上层应用是在用户态&#xff0c;是无法直接操控底层的硬件的。我们需要利用系统调用&#xff08;open、read、write等&#xff09;&#xff0c;进入内核态…