当前位置: 首页 > news >正文

西安市城市建设档案馆官方网站站长之家网站模板

西安市城市建设档案馆官方网站,站长之家网站模板,泰安企业建站公司排行,网站建设前的需求分析105.从前序与中序遍历序列构造二叉树 二叉树前序遍历顺序:根左右 二叉树中序遍历顺序:左根右 只要我们在中序遍历中定位到根节点,那么我们就可以分别知道左子树和右子树中的节点数目。由于同一颗子树的前序遍历和中序遍历的长度显然是相同的…

105.从前序与中序遍历序列构造二叉树

image-20231016112007898

二叉树前序遍历顺序:根左右

二叉树中序遍历顺序:左根右

只要我们在中序遍历中定位到根节点,那么我们就可以分别知道左子树和右子树中的节点数目。由于同一颗子树的前序遍历和中序遍历的长度显然是相同的,因此我们就可以对应到前序遍历的结果中,对上述形式中的所有左右括号进行定位。

这样以来,我们就知道了左子树的前序遍历和中序遍历结果,以及右子树的前序遍历和中序遍历结果,我们就可以递归地对构造出左子树和右子树,再将这两颗子树接到根节点的左右位置。

注意:

在中序遍历中对根节点进行定位时,一种简单的方法是直接扫描整个中序遍历的结果并找出根节点,但这样做的时间复杂度较高。我们可以考虑使用哈希表来帮助我们快速地定位根节点。对于哈希映射中的每个键值对,键表示一个元素(节点的值),值表示其在中序遍历中的出现位置。在构造二叉树的过程之前,我们可以对中序遍历的列表进行一遍扫描,就可以构造出这个哈希映射。在此后构造二叉树的过程中,我们就只需要 O(1) 的时间对根节点进行定位了。

/*** 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 {private Map<Integer,Integer> indexMap;public TreeNode myBuildTress(int[] preorder,int[] inorder,int preorder_left,int preorder_right,int inorder_left,int inorder_right){if(preorder_left > preorder_right){return null;}//前序遍历中的第一个节点就是根节点int preorder_root = preorder_left;//在中序遍历中定位根节点int inorder_root = indexMap.get(preorder[preorder_root]);//先把根节点建立出来TreeNode root = new TreeNode(preorder[preorder_root]);//得到左子树的节点数目int size_left_subtree = inorder_root - inorder_left;//递归地构造左子树,并连接到根节点//先序遍历中(从左边界+1开始的size_left_subtree)个元素就对应了中序遍历中(从左边界开始到根节点定位-1)的元素root.left = myBuildTress(preorder,inorder,preorder_left+1,preorder_left+size_left_subtree,inorder_left,inorder_root - 1);//递归构造右子树,并连接到根节点//先序遍历中(从左边界+1+左子树节点数目开始到右边界)的元素就对应了中序遍历中(从根节点定位+1到右边界)的元素root.right = myBuildTress(preorder,inorder,preorder_left+size_left_subtree+1,preorder_right,inorder_root+1,inorder_right);return root;}public TreeNode buildTree(int[] preorder, int[] inorder) {int n = preorder.length;//构造哈希映射,帮我们快读定位根节点indexMap = new HashMap<Integer,Integer>();for(int i = 0;i<n;i++){indexMap.put(inorder[i],i);}return myBuildTress(preorder,inorder,0,n-1,0,n-1);}
}
http://www.hkea.cn/news/297211/

相关文章:

  • 国外学做咖啡的网站百度高级搜索网址
  • 建网站开源代码游戏推广怎么找玩家
  • 莱州哪里有做网站的浙江网站建设平台
  • ps网站设计与制作免费推广seo
  • 网站查询功能怎么做关键词搜索量怎么查
  • 付费网站推广网站优化包括哪些内容
  • 在日本做色情网站广州seo外包
  • 最棒的网站建设考研最靠谱的培训机构
  • 广州建设企业网站黑河seo
  • 招商网站建设性价比高seo排名优化的
  • 产品网站怎么做的长沙正规关键词优化价格从优
  • 怎样查询江西省城乡建设厅网站杭州seo网
  • 网站建设空间是指什么软件网站优化最为重要的内容是
  • 做美工要开通什么网站的会员呢新网站友链
  • 网站集约化建设推进情况推广app赚钱
  • 番禺大石做网站域名污染查询网站
  • 长沙市在建工程项目免费seo快速排名工具
  • 南宁定制网站制作电话图片外链生成工具
  • 哪些网站做的海报比较高大上百度客服电话是多少
  • 菏泽网站建设电话常州seo外包
  • 做木皮的网站裂变营销五种模式十六种方法
  • 精美 企业网站模板微信软文推广怎么做
  • 怎么建立一个网站里面可以查询资料百度权重域名
  • 网站建设顺序镇江交叉口优化
  • 低价企业网站搭建软文新闻发布网站
  • 创造与魔法官方网站做自己喜欢的事seo视频
  • 淘宝联盟推广网站怎么做吉安seo招聘
  • 工程招聘网站如何免费制作自己的网站
  • 网站建设调研问卷搜易网托管模式的特点
  • 在哪个网站可以做java面试题宁德市蕉城区疫情