微网站与微信网站网站开发属于什么专业
微网站与微信网站,网站开发属于什么专业,php网站开发环境一,ppt制作软件手机版下载免费给定两个整数数组 preorder 和 inorder #xff0c;其中 preorder 是二叉树的先序遍历#xff0c; inorder 是同一棵树的中序遍历#xff0c;请构造二叉树并返回其根节点。
示例 1: 输入: preorder [3,9,20,15,7], inorder [9,3,15,20,7] 输出: [3,9,20,null,null,15,7] …给定两个整数数组 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]
/*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:unordered_mapint,int hash;//哈希表用于存放中序序列值的下标方便查找TreeNode* build(vectorint preorder,vectorint inorder,int pl,int pr,int il,int ir){if(plpr||ilir){return nullptr;}TreeNode* nodenew TreeNode(preorder[pl]);//前序序列的第一个节点是此轮的根节点int splithash[preorder[pl]];//根节点在中序序列中的下标int leftnumssplit-il;//左子树的节点数//左孩子前中序序列边界不同:根节点[序列长度]or[序列长度]根节点node-leftbuild(preorder,inorder,pl1,plleftnums,il,illeftnums-1);//右孩子前中序序列的边界是一样的node-rightbuild(preorder,inorder,plleftnums1,pr,illeftnums1,ir);return node;}TreeNode* buildTree(vectorint preorder, vectorint inorder) {//时间复杂度O(N),空间复杂度O(N)int npreorder.size();for(int i0;in;i){hash[inorder[i]]i;}//初始化哈希表//pl:前序序列左边界 pr:前序序列右边界 il:中序序列左边界 ir:中序序列右边界return build(preorder,inorder,0,n-1,0,n-1);}
};
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/86164.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!