F - Pre-order and In-order

用先序和中序 来构建树。。
树本身是递归结构。所以构建过程一般也会是递归的

实现就是:🔥通过先序的root 找到中序的root位置 分割点 。再通过中序 root的位置 反向找到先序到分割点的len。。。 一直反复进行这个过程

细节
1 要知道先序 他是 root +左子树+右子树
中序是 左子树+root+右子树 这样的结构 。。如果不清楚的话 就无从下手

l r 这边代表先序的区间范围 xy 代表中序的。
l r x y 一定要分别维护 因为 他们随着递归 中序和先序对应的区间位置会发生改变。

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define ll __int128_t
#define ar array<int, 2>
#define arr array<int, 3>
int  n, m, k, inf = 1LL << 61, mod = 998244353;// 1e9+7;
const int N = 5e5 + 50;
int a[N], b[N], p[N];
ar ans[N];
int  dfs(int l, int r, int x, int y) {
	// if (l == r) 这个特判可以去掉
	// 	return a[l];
	if (l > r)return 0;//子树为空的时候 就会lr交错
	int t = a[l];
	int j = p[t];
	if (j > y || j < x || a[1] != 1) {// 我们把根节点不=1 也写在这里。。省事
		cout << -1;
		exit(0);
	}
	int len = j - x;
	ans[t][0] = dfs(l + 1, l + len, x, j - 1);
	ans[t][1] = dfs(l + len + 1, r, j + 1, y);
	return t;
};
void solve() {
	cin >> n;
	for (int i = 1; i <= n; ++i)
		cin >> a[i];
	for (int i = 1; i <= n; ++i) {
		cin >> b[i];
		p[b[i]] = i;
	}

	dfs(1, n, 1, n);
	for (int i = 1; i <= n; ++i)
		cout << ans[i][0] << ' ' << ans[i][1] << '\n';
};




signed main() {
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout << fixed << setprecision(15);
#ifdef DEBUG
	freopen("../1.in", "r", stdin);
#endif
	//init_f();
	//init();
	//expr();
	// int T; cin >> T; while(T--)
	solve();
	return 0;
}



在atc写到这题的时候 有点梦回leetcode 。。哈哈。

  • 8
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值