求调!!!
  • 板块灌水区
  • 楼主zhe_chen_Aya
  • 当前回复2
  • 已保存回复2
  • 发布时间2024/12/23 20:36
  • 上次更新2024/12/24 10:49:23
查看原帖
求调!!!
1580057
zhe_chen_Aya楼主2024/12/23 20:36

题目

#include<bits/stdc++.h>
#include<unordered_map>
using namespace std;
long long n, ls, lls, k, k2;
bool book[100001];
vector<long long> v[1000001];
unordered_map<int, bool> m[3001];
long long a[1001];
void DFS(int d, int l) {
	m[l][d] = 1;
	for (auto i : v[d]) {
		DFS(i, l);
	}
}
void BFS(int k) {
	queue<int> q;
	q.push(k);
	book[k] = 1;
	memset(book, 0, sizeof(book));
	while (!q.empty()) {
		int ls = q.front();
		q.pop();
		cout << ls << " ";
		for (auto i : v[ls]) {
			if (!book[i]) {
				book[i] = 1;
				q.push(i);
			}
		}
	}
}
int main() {
	cin >> n;
	for (int i = 1; i < n; i++) {
		m[0][i] = 1;
		cin >> ls;
		v[ls].push_back(i);
	}
	for (int i = 1; i < n; i++) {
		DFS(i, i);
	}
	cin >> k;
	while (k--) {
		cin >> k2;
		for (int i = 1; i <= k2; i++) {
			cin >> a[i];
		}
		for (int i = n - 1; i >= 0; i--) {
			bool f = 1;
			for (int j = 1; j <= k2; j++) {
				if (!m[i][a[j]]) {
					f = 0;
					break;
				}
			}
			if (f) {
				cout << i << "\n";
				break;
			}
		}
	}
	return 0;
}
2024/12/23 20:36
加载中...