LeetCode:889. 根据前序和后序遍历构造二叉树

class Solution {

public:

unordered_map<int,int>valToIndex;

TreeNode* constructFromPrePost(vector<int>& preorder, vector<int>& postorder) {

for(int i=0;i<postorder.size();i++){

valToIndex[postorder[i]]=i;

}

return build(preorder,0,preorder.size()-1,

postorder,0,postorder.size()-1);

}

TreeNode* build(vector<int>& preorder,int preStart,int preEnd,

vector<int>& postorder,int postStart,int postEnd){

if(preStart>preEnd){

return nullptr;

}

if(preStart==preEnd){

return new TreeNode(preorder[preStart]);

}

int rootVal=preorder[preStart];

int leftRootVal=preorder[preStart+1];

int index=valToIndex[leftRootVal];

int leftsize=index-postStart+1;

//先构造出当前根节点

TreeNode* root=new TreeNode(rootVal);

root->left=build(preorder,preStart+1,preStart+leftsize,

postorder,postStart,index);

root->right=build(preorder,preStart+leftsize+1,preEnd,

postorder,index+1,postEnd-1);

return root;

}

};

相关推荐
EdmundXjs12 分钟前
大模型核心概念解读
人工智能·算法
lookaroundd13 分钟前
llm-compressor 普通量化调用链分析
python·算法
小羊在睡觉27 分钟前
力扣239. 滑动窗口最大值
数据结构·后端·算法·leetcode·go
兰令水31 分钟前
topcode【随机算法题】【2026.5.20打卡-java版本】
java·开发语言·算法
不吃土豆的马铃薯37 分钟前
Spdlog 入门:日志记录器与日志槽基础详解
服务器·开发语言·c++·c·日志·spdlog
此生决int41 分钟前
算法从入门到精通——前缀和
c++·算法·蓝桥杯
我星期八休息1 小时前
Linux系统编程—库制作与原理
linux·运维·服务器·数据结构·人工智能·python·散列表
大大杰哥1 小时前
leetcode hot100(4)矩阵
算法·leetcode·矩阵
Fuyo_11191 小时前
C++中的活字印刷术——模板·初阶
开发语言·c++·笔记
小白|1 小时前
cmake:昇腾CANN构建系统完全指南
java·c++·算法