求调
  • 板块灌水区
  • 楼主luogu140658945
  • 当前回复0
  • 已保存回复0
  • 发布时间2025/1/4 10:41
  • 上次更新2025/1/4 15:28:05
查看原帖
求调
1112643
luogu140658945楼主2025/1/4 10:41

题目

#include<bits/stdc++.h>
#include<unordered_map>
using namespace std;
long long n, ls, i, k, k2;
bool book[100001];
vector<long long> v[1000001];
unordered_map<int, bool> m[3001];
long long a[1001];
void DFS(int d) {
	m[i][d] = 1;
	for (auto i : v[d]) {
		DFS(i);
	}
}
int main() {
	cin >> n;
	for (int i = 1; i < n; i++) {
		m[0][i] = 1;
		cin >> ls;
		v[ls].push_back(i);
	}
	for (i = 1; i < n; i++) {
		DFS(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;
}
2025/1/4 10:41
加载中...