⭐北邮复试刷题105. 从前序与中序遍历序列构造二叉树__递归分治 (力扣每日一题)

news/发布时间2024/5/15 18:23:11

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 保证 为二叉树的中序遍历序列

题解:

我们使用递归分治思想,因对于所给中序和前序,可通过前序序列确定第一个节点,再通过此节点在中序序列中的位置进而确定左右子树各自的中序序列,之后再通过其确定左右子树各自的前序序列,以此可进行递归处理;
同时注意某子树的中序序列长度和前序序列长度必为相等,可依据此性质确定递归时inorder数组和preorder数组下标起点终点该如何选择;
递归即对每个子树的中序和后序序列分别按照上述思想处理即可;

代码:

/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/// 贪心法 失败
// class Solution {
//     public TreeNode buildTree(int[] preorder, int[] inorder) {
//         // 哈希表维护中序顺序,从而判断两元素之间方向关系
//         Map<Integer,Integer> map = new HashMap<>(); 
//         for(int i=0;i<inorder.length;i++){
//             map.put(inorder[i],i);
//         }//         // 建造节点依靠先序,中序作为验证判断,从而选择l或r方向延申
//         // 初始化第一个位置,因其为确定且唯一
//         TreeNode res = new TreeNode(preorder[0]);
//         TreeNode temp = res;//         // 其余元素需要加入中序判断
//         for(int i=1;i<preorder.length;i++){
//             int level = map.get(preorder[i]);
//             if(level > map.get(temp.val)){
//                 // 每次都叫node_new,但是分配区域不会回收
//                 // 只是名字被另一片区域剥夺,但因使用指针已经连接好,故不会混淆
//                 TreeNode node_new = new TreeNode(preorder[i]);
//                 temp.right = node_new;
//                 temp = temp.right;
//             }
//             else{
//                 // 同上 区别是若遍历到的节点在temp右方则必定temp加入此点后向right移动
//                 // 若在temp左方 需等待 因可能右方还有节点 
//                 // 当然也存在右方无节点情况 此时则需要判断下一节点是否仍为temp的left
//                 // 若是 则temp向left移动
//                 if(temp.left == null){
//                     TreeNode node_new = new TreeNode(preorder[i]);
//                     temp.left = node_new;
//                 }
//                 else{
//                     temp = temp.left;
//                     // 回溯未处理情况
//                     i--;
//                 } 
//             }
//         }//         return res;
//     }
// }// 递归法
class Solution {Map<Integer,Integer> map = new HashMap<>(); public TreeNode buildTree(int[] preorder, int[] inorder) {// 哈希表维护中序顺序,从而判断两元素之间方向关系for(int i=0;i<inorder.length;i++){map.put(inorder[i],i);}return ToBuildTree(preorder,inorder,0,preorder.length-1,0,inorder.length-1);}public TreeNode ToBuildTree(int[] preorder,int[] inorder,int preStart,int preEnd,int inStart,int inEnd){// 中序序列和先序序列长度必为相等,因此只需判断一个即可if(preStart > preEnd)return null;   // 对于递归设置一个终止条件即可// 根节点可立刻确定TreeNode res = new TreeNode(preorder[preStart]);// 此根在中序遍历中下标位置int inorder_pre = map.get(preorder[preStart]);// 运用每个子树的中序序列和其对应的前序序列长度相等的性质,可推断出左子树和右子树前序序列分界点int placeLeft = inorder_pre-1 - inStart;res.left = ToBuildTree(preorder,inorder,preStart+1,preStart+1+placeLeft,inStart,inorder_pre-1);int placeRight = inEnd - (inorder_pre+1);  res.right = ToBuildTree(preorder,inorder,preEnd-placeRight,preEnd,inorder_pre+1,inEnd);return res;}
}

结果:

在这里插入图片描述

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

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

相关文章

网站管理新利器:免费在线生成 robots.txt 文件!

&#x1f916; 探索网站管理新利器&#xff1a;免费在线生成 robots.txt 文件&#xff01; 你是否曾为搜索引擎爬虫而烦恼&#xff1f;现在&#xff0c;我们推出全新的在线 robots.txt 文件生成工具&#xff0c;让你轻松管理网站爬虫访问权限&#xff0c;提升网站的可搜索性和…

中期国际2.19黄金市场分析:美国通胀数据火热,黄金面临高利率削弱的挑战

周一(2月19日)亚市&#xff0c;现货黄金震荡走高&#xff0c;目前交投于2018.32美元/盎司左右&#xff0c;涨幅约为0.25%。上周五金价收涨0.46%&#xff0c;报价2013.46美元/盎司&#xff0c;虽然黄金周五略有上涨&#xff0c;但由于通胀数据炽热&#xff0c;美联储提前降息的可…

pikachu靶场-暴力破解

目录 1.基于表单的暴力破解&#xff1a; 2.验证码绕过(on server)&#xff1a; 3.验证码绕过(on client)&#xff1a; 1.基于表单的暴力破解&#xff1a; 个人理解&#xff1a;无验证码和各种校验程序&#xff0c;最为简单的暴力破解。 随便输入错误的账密&#xff0c;burp抓…

Linux 权限详解

目录 一、权限的概念 二、权限管理 三、文件访问权限的相关设置方法 3.1chmod 3.2chmod ax /home/abc.txt 一、权限的概念 Linux 下有两种用户&#xff1a;超级用户&#xff08; root &#xff09;、普通用户。 超级用户&#xff1a;可以再linux系统下做任何事情&#xff…

【AI大语言模型】ChatGPT在地学、GIS、气象、农业、生态、环境等领域中的应用

以ChatGPT、LLaMA、Gemini、DALLE、Midjourney、Stable Diffusion、星火大模型、文心一言、千问为代表AI大语言模型带来了新一波人工智能浪潮&#xff0c;可以面向科研选题、思维导图、数据清洗、统计分析、高级编程、代码调试、算法学习、论文检索、写作、翻译、润色、文献辅助…

文生视频模型调研

文生视频只有OpenAI的Sora&#xff0c;其他的&#xff08;&#xff09;都是动图。 OpenAI发布了可以生成60s视频的Sora模型。刚刚发布的google的Gemini pro 1.5就一下子变得无人问津了&#xff0c;太尴尬了。 在这之前视频生成的天花板是Runway&#xff0c;支持最多18s视频生成…

react使用Map方法遍历列表不显示的问题

问题&#xff1a; 在最开始搭建选项卡的时候&#xff0c;我的js代码是这样的 import React, { Component } from react import ./css/02-maizuo.css export default class App extends Component {state {list: [{id: 1,text: 电影},{id: 2,text: 影院}, {id: 3,text: 我的}…

机器学习——正规方程

正规方程的基本介绍 之前我们使用梯度下降算法求代价函数J(θ)的最小值&#xff0c;而梯度下降算法是通过一步步不断地迭代来收敛到全局最小值&#xff0c;如下 而正规方程则是另一种求解J(θ)最小值的方法&#xff0c;并且正规方程不需要通过迭代&#xff0c;而是一次性得到θ…

09、全文检索 -- Solr -- SpringBoot 整合 Spring Data Solr (生成DAO组件 和 实现自定义查询方法)

目录 SpringBoot 整合 Spring Data SolrSpring Data Solr的功能&#xff08;生成DAO组件&#xff09;&#xff1a;Spring Data Solr大致包括如下几方面功能&#xff1a;Query查询&#xff08;属于半自动&#xff09;代码演示&#xff1a;1、演示通过dao组件来保存文档1、实体类…

Midjourney的宁静秘境:遇见内心的平和与美丽

所有的提示词&#xff0c;gzh&#xff1a;七哥的AI日常 在这个充满快节奏和压力的时代&#xff0c;我们时常渴望逃离喧嚣&#xff0c;寻找一处心灵的净土。Midjourney用一系列精心创作的图片&#xff0c;带你踏上一段宁静的心灵之旅&#xff0c;让你在欣赏美女、风景和冥想等元…

【Java EE初阶二十二】https的简单理解

1. 初识https 当前网络上,主要都是 HTTPS 了,很少能见到 HTTP.实际上 HTTPS 也是基于 HTTP.只不过 HTTPS 在 HTTP 的基础之上, 引入了"加密"机制&#xff1b;引入 HTTPS 防止你的数据被黑客篡改 &#xff1b; HTTPS 就是一个重要的保护措施.之所以能够安全, 最关键的…

vue路由详解

vue路由详解 一、路由属性配置说明二、页面跳转&#xff08;1&#xff09;router-link标签跳转&#xff08;2&#xff09; 编程式导航 - JS代码内部跳转&#xff08;3&#xff09;其他常用方法 三、子路由 - 路由嵌套&#xff08;1&#xff09; src/components/Home.vue&#x…

STL - hash

1、unordered系列关联式容器 在C98中&#xff0c;STL提供了底层为红黑树结构的一系列关联式容器&#xff0c;在查询时效率可达到O()&#xff0c;即最差情况下需要比较红黑树的高度次&#xff0c;当树中的节点非常多时&#xff0c;查询效率也不理想。最好 的查询是&#xff0c;进…

二叉树入门算法题详解

二叉树入门题目详解 首先知道二叉树是什么&#xff1a; 代码随想录 (programmercarl.com) 了解后知道其实二叉树就是特殊的链表&#xff0c;只是每个根节点节点都与两个子节点相连而其实图也是特殊的链表&#xff0c;是很多节点互相连接&#xff1b;这样说只是便于理解和定义…

Python中嵌套自定义类型的JSON序列化与反序列化

对于经常用python开发得小伙伴来说&#xff0c;Python的JSON序列化和反序列化功能非常方便和实用。JSON&#xff08;JavaScript Object Notation&#xff09;其实就是一种轻量级的数据交换格式&#xff0c;易于阅读和编写&#xff0c;也易于机器解析和生成。在Python中&#xf…

Mkdocs-Wcowin博客主题

Mkdocs-Wcowin主题 通过主题和目录以打开文章基于Material for MkDocs美化 简洁美观&#xff0c;功能多元化简单易上手&#xff0c;小白配置 教程详细&#xff0c;清晰易懂 展示 感受一下它的简洁美观&#xff1a;Mkdocs-Wcowin主题 主页 文章页 博客页 标签页 简…

webpack的使用(中)

前言&#xff1a;&#xff08;承接webpack的使用(上)&#xff09;在实际开发过程中&#xff0c;webpack 默认只能打包处理以 .js 后缀名结尾的模块&#xff0c;其他非 js 后缀名结尾的模块&#xff0c;webpack 默认处理不了&#xff0c;需要调用 loader 加载器才可以正常打包&a…

启动node服务报错Error: listen EACCES: permission denied 0.0.0.0:5000

启动node服务报错&#xff1a; 解决方案&#xff1a; 将监听端口改成3000或者其他 修改后结果&#xff1a; 参考原文&#xff1a; Error: listen EACCES: permission denied_error when starting dev server: error: listen eacc-CSDN博客

阿里云香港轻量应用服务器是什么线路?

阿里云香港轻量应用服务器是什么线路&#xff1f;不是cn2。 阿里云香港轻量服务器是cn2吗&#xff1f;香港轻量服务器不是cn2。阿腾云atengyun.com正好有一台阿里云轻量应用服务器&#xff0c;通过mtr traceroute测试了一下&#xff0c;最后一跳是202.97开头的ip&#xff0c;1…

DS:循环队列的实现

创作不易&#xff0c;给个三连吧&#xff01;&#xff01; 一、前言 对于循环队列&#xff0c;博主也是源自于一道力扣的OJ题 力扣&#xff1a;循环队列的设置 后来我在网上查过&#xff0c;这个循环队列是有自己的应用场景的&#xff01;&#xff01;并不是出题者为了出题…
推荐文章