加载中...

二叉树的结构

https://www.acwing.com/problem/content/description/4274/

#include<bits/stdc++.h>
#include<string.h>
using namespace std;
const int N = 1010;
int post[N], in[N], pos[N];
int l[N], r[N], f[N];
int depth[N];
int n, m;

int build(int pl, int pr, int il, int ir)
{
	int root = post[pr];
	int k = pos[root];

	if (k > il)
	{
		int t = build(pl, pr - 1 - (ir - k - 1) - 1, il, k - 1);
		l[root] =t;
		f[t] = root;
	}
	if (k < ir)
	{
		int t = build(pr - 1 - (ir - k - 1), pr - 1, k + 1, ir);
		r[root] = t;
		f[t] = root;
	}

	return root;
}

void dfs(int root,int u)
{
	if (root == 0) return;
	depth[root] = u;
	if(l[root])dfs(l[root], u + 1);
	if(r[root])dfs(r[root], u + 1);
}

bool check(int root)
{
	if (root == 0) return true;
	if ((l[root] != 0 && r[root] != 0) || ((l[root] == 0 && r[root] == 0)))
	{
		
		return check(l[root]) && check(r[root]);;
	}
	else
	{
		return false;
	}
}

int main()
{
	cin >> n;
	for (int i = 1; i <= n; i++) cin >> post[i]; 
	for (int i = 1; i <= n; i++) cin >> in[i], pos[in[i]] = i;
	int root = build(1, n, 1, n);
	dfs(root,1);
	//cout<<root<<endl;
	//cout << r[2] << endl;
	cin >> m;
	getchar();
	string s;
	for (int i = 1; i <= m; i++)
	{
		getline(cin,s);
		if (s.find("root")!=-1)
		{
			stringstream ssin(s);
			vector<int> temp(2);
			sscanf(s.c_str(), "%d", &temp[0]);
			cout << (temp[0]== root ? "Yes" : "No") << endl;
		}
		if (s.find("siblings") != -1)
		{
			stringstream ssin(s);
			vector<int> temp(2);
			sscanf(s.c_str(), "%d and %d", &temp[0], &temp[1]);
			if (temp[0] != temp[1]) cout << (f[temp[0]]==f[temp[1]] ? "Yes" : "No") << endl;
			else cout << "No" << endl;
		}
		if (s.find("parent") != -1)
		{
			vector<int> temp(2);
			stringstream ssin(s);
			sscanf(s.c_str(), "%d is the parent of %d", &temp[0], &temp[1]);
			cout << (temp[0] == f[temp[1]] ? "Yes" : "No") << endl;
		}
		if (s.find("left") != -1)
		{
			vector<int> temp(2);
			stringstream ssin(s);
			sscanf(s.c_str(), "%d is the left child of %d", &temp[0], &temp[1]);
			cout << (temp[0] == l[temp[1]] ? "Yes" : "No") << endl;
		}
		if (s.find("right") != -1)
		{
			vector<int> temp(2);
			stringstream ssin(s);
			sscanf(s.c_str(), "%d is the right child of %d", &temp[0], &temp[1]);
			cout << (temp[0] == r[temp[1]] ? "Yes" : "No") << endl;
		}
		if (s.find("level") != -1)
		{
			vector<int> temp(2);
			stringstream ssin(s);
			sscanf(s.c_str(), "%d and %d", &temp[0], &temp[1]);
			cout << (depth[temp[0]] == depth[temp[1]] ? "Yes" : "No") << endl;
		}
		if (s.find("full") != -1)
		{
			cout << (check(root) == true ? "Yes" : "No") << endl;
		}
	}
	return 0;
}
posted @ 2022-08-24 22:37  英雄不问出处c  阅读(15)  评论(0编辑  收藏  举报