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

驻马店制作网站的公司郑州网站推广哪家专业

驻马店制作网站的公司,郑州网站推广哪家专业,网站设计项目建设内容,金融网站模板免费下载【LetMeFly】106.从中序与后序遍历序列构造二叉树#xff1a;分治#xff08;递归#xff09;——五彩斑斓的题解#xff08;若不是彩色的可以点击原文链接查看#xff09; 力扣题目链接#xff1a;https://leetcode.cn/problems/construct-binary-tree-from-inorder-an…【LetMeFly】106.从中序与后序遍历序列构造二叉树分治递归——五彩斑斓的题解若不是彩色的可以点击原文链接查看 力扣题目链接https://leetcode.cn/problems/construct-binary-tree-from-inorder-and-postorder-traversal/ 给定两个整数数组 inorder 和 postorder 其中 inorder 是二叉树的中序遍历 postorder 是同一棵树的后序遍历请你构造并返回这颗 二叉树 。 示例 1: 输入inorder [9,3,15,20,7], postorder [9,15,7,20,3] 输出[3,9,20,null,null,15,7]示例 2: 输入inorder [-1], postorder [-1] 输出[-1]提示: 1 inorder.length 3000postorder.length inorder.length-3000 inorder[i], postorder[i] 3000inorder 和 postorder 都由 不同 的值组成postorder 中每一个值都在 inorder 中inorder 保证是树的中序遍历postorder 保证是树的后序遍历 方法一分治递归 类似于从前序与中序建树我们知道 中序遍历左子树 根 右子树后序遍历左子树 右子树 根 写一个函数dfs接收中序遍历数组和后序遍历数组作为参数 根据后序遍历数组的最后一个元素为根节点建立节点找到根节点在中序遍历数组中的位置 以此可得到左子树和右子树的长度信息 以此可确定左子树和右子树在两个数组中的位置 递归建立左子树和右子树 递归的终止条件为“中序遍历数组为空”此时返回空节点。 Tips: 可以在预处理时建立一个哈希表以便能快速地找到根节点在中序遍历数组中的位置。 时间复杂度 O ( N ) O(N) O(N)其中 N N N是节点个数空间复杂度 O ( N ) O(N) O(N) AC代码 C class Solution { private:unordered_mapint, vectorint::iterator ma;TreeNode* dfs(vectorint::iterator inLeft, vectorint::iterator inRight, vectorint::iterator postLeft, vectorint::iterator postRight) {if (inLeft inRight) {return nullptr;}TreeNode* thisNode new TreeNode(*(postRight - 1));vectorint::iterator loc ma[*(postRight - 1)];thisNode-left dfs(inLeft, loc, postLeft, postLeft (loc - inLeft));thisNode-right dfs(loc 1, inRight, postLeft (loc - inLeft), postRight - 1);return thisNode;} public:TreeNode* buildTree(vectorint inorder, vectorint postorder) {for (vectorint::iterator it inorder.begin(); it ! inorder.end(); it) {ma[*it] it;}return dfs(inorder.begin(), inorder.end(), postorder.begin(), postorder.end());} };Python # from typing import List, Optional# # Definition for a binary tree node. # class TreeNode: # def __init__(self, val0, leftNone, rightNone): # self.val val # self.left left # self.right rightclass Solution:def dfs(self, inorder: List[int], inLeft: int, inRight: int, postorder: List[int], postLeft: int, postRight: int) - Optional[TreeNode]:if inLeft inRight:return NonethisNode TreeNode(postorder[postRight - 1])loc self.ma[postorder[postRight - 1]]thisNode.left self.dfs(inorder, inLeft, loc, postorder, postLeft, postLeft (loc - inLeft))thisNode.right self.dfs(inorder, loc 1, inRight, postorder, postLeft (loc - inLeft), postRight - 1)return thisNodedef buildTree(self, inorder: List[int], postorder: List[int]) - TreeNode:self.ma dict()for i in range(len(inorder)):self.ma[inorder[i]] ireturn self.dfs(inorder, 0, len(inorder), postorder, 0, len(postorder))同步发文于CSDN原创不易转载经作者同意后请附上原文链接哦~ Tisfyhttps://letmefly.blog.csdn.net/article/details/136204741
http://www.pierceye.com/news/386355/

相关文章:

  • 自己做的网站访问不了建站如何挣钱
  • 网盘做网站做网站推广员工
  • 河北正规网站建设比较网页制作平台哪家好
  • 2017网站seo如何做wordpress设置登录背景
  • 网站的模块怎么做网站建设的技术支持包括
  • 青岛网站设计哪家好游戏小程序开发定制
  • 建设网站西丽提升网站建设品质
  • 大良营销网站建设方案广东东莞划定多个高风险区
  • 毕业设计做网站用什么品牌网站建设新闻
  • c 网站开发用的人多吗做it行业招标网站有哪些
  • 招聘做牙技工的网站用html框架做网站
  • 本地wordpress站点上传央企网站群建设
  • 广州免费自助建站开发wordpress公园
  • 淘宝客建网站简单网站建设优化推广
  • 长沙做网站找哪家好毕业设计开题报告网站开发
  • 可以写代码的网站有哪些问题吗网页设计与网站建设期末考试试卷
  • 美工做网站怎么收费网站设计规范
  • 建网站需要注意的问题企业整合营销
  • 2018网站开发的革新wordpress 更新数据库
  • 做现金贷的网站有哪些如何自己建立一个网站
  • 网站制作公司前十名wordpress保存的字体大小
  • 网站设计思路方案海外购物网站哪个最好
  • 哪个网站做课件能赚钱青岛制作网站的
  • 深圳做网站排名公司哪家好html网页设计实训报告范文
  • 外贸网站开发做动画 的 网站有哪些软件下载
  • 中国建设银行吉林省分行官网站wordpress形式
  • 做门户网站可以用的字体黑龙江建设教育网站
  • 怎么做网站建设赚钱知名品牌设计logo解析
  • wordpress全站静态化做公司网站 找谁做
  • 广安网站建设哪家好网站模板下载网站