您的位置:首页 > 其它

团体程序设计天梯赛-练习集 L2-011. 玩转二叉树

2016-07-06 12:43 288 查看
团体程序设计天梯赛-练习集

L2-011. 玩转二叉树

https://www.patest.cn/contests/gplt/L2-011

和树的遍历那道题一样。

#include<iostream>
#include<cstdio>
using namespace std;
int N, z;
int qian[35], zhong[35], cen[35];
void findc(int s, int d, int cnt) {
if (s > d) {
return;
}
if (z > N - 1) {
return;
}
for (int i = s; i <= d; i++) {
if (zhong[i] == qian[z]) {
cen[i] = cnt;
z++;
findc(s, i - 1, cnt + 1);
findc(i + 1, d, cnt + 1);
break;
}
}
}
int main() {
while (scanf("%d\n", &N) != EOF) {
for (int i = 0; i < N; i++) {
scanf("%d", &zhong[i]);
}
for (int i = 0; i < N; i++) {
scanf("%d", &qian[i]);
}
z = 0;
findc(0, N - 1, 0);
for (int i = 0, k = 0; k < N; i++) {
for (int j = N - 1; j >= 0; j--) {
if (cen[j] == i) {
k++;
printf(i ? " %d" : "%d", zhong[j]);
}
}
}
printf("\n");
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  二叉树