#include <bits/stdc++.h>
using namespace std;
const int N = 10110;
struct Tree {
int u, l, r;
}TNode[N];
int midorder[N], preorder[N];
int main() {
int n;
cin >> n;
for (int i = 0; i < N; i++) TNode[i].u = -1;
for (int i = 0; i < n; i++) {
cin >> midorder[i];
}
for (int i = 0; i < n; i++) {
cin >> preorder[i];
}
int pos = 0;
function<void(int, int, int)> build = [&](int l, int r, int u) {
if (l >= r) {
TNode[u].u = -1;
return;
}
int root = preorder[pos++];
TNode[u].u = root;
TNode[u].l = 2 * u;
TNode[u].r = 2 * u + 1;
int mid = find(midorder, midorder + r, root) - midorder;
build(l, mid, 2 * u);
build(mid + 1, r, 2 * u + 1);
};
build(0, n, 1);
vector<int> res;
queue<int> q;
q.push(1);
while (q.size()) {
int u = q.front();
q.pop();
if (TNode[u].u != -1) {
res.push_back(TNode[u].u);
q.push(TNode[u].r);
q.push(TNode[u].l);
}
}
for (int i = 0; i < res.size(); i++) {
cout << res[i] << " "[i == res.size() - 1];
}
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
2020-03-17 字符串的操作:字符串变换(蓝桥杯训练系统)
2020-03-17 递归+DP:爬楼梯问题
2020-03-17 (Good topic)哈希表:拼写单词 (3.17 leetcode每日打卡)