4601: 【GESP2312六级】工作沟通
内存限制:128 MB
时间限制:1.000 S
评测方式:文本比较
命题人:
提交:1
解决:1
题目描述

输入
第一行一个整数$N$ ,表示员工的数量。
第二行$N-1$ 个用空格隔开的正整数,依次为$f_1,f_2,...,f_{N-1}$ 。
第三行一个整数$Q$ ,表示共有$Q$ 场合作需要安排。
接下来$Q$ 行,每行描述一场合作:开头是一个整数$m$ ($2\le m\le N$ ),表示参与本次合作的员工数量;接着是$m$个整数,依次表示参与本次合作的员工编号(保证编号合法且不重复)。
保证公司结构合法,即不存在任意一名员工,其本人是自己的直接或间接领导。
第二行$N-1$ 个用空格隔开的正整数,依次为$f_1,f_2,...,f_{N-1}$ 。
第三行一个整数$Q$ ,表示共有$Q$ 场合作需要安排。
接下来$Q$ 行,每行描述一场合作:开头是一个整数$m$ ($2\le m\le N$ ),表示参与本次合作的员工数量;接着是$m$个整数,依次表示参与本次合作的员工编号(保证编号合法且不重复)。
保证公司结构合法,即不存在任意一名员工,其本人是自己的直接或间接领导。
输出
输出$Q$ 行,每行一个整数,依次为每场合作的主持人选。
样例输入 复制
5
0 0 2 2
3
2 3 4
3 2 3 4
2 1 4
样例输出 复制
2
2
0
提示
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <string>
#include <map>
#include <iostream>
#include <cmath>
#include <vector>
using namespace std;
const int N = 305;
int fa[N], dep[N];
bool vis[N];
vector<int> ch[N];
int getdep(int x) {
return x == 0 ? 0 : getdep(fa[x]) + 1;
}
void dfs(int x) {
vis[x] = 1;
for (int y : ch[x])
dfs(y);
}
bool check(int x, int n, const vector<int> &vec) {
for(int i = 0; i <= n; i ++)
vis[i] = 0;
dfs(x);
for (int y : vec)
if(! vis[y])
return 0;
return 1;
}
int main() {
// freopen("data/1.in", "r", stdin);
// freopen("tmp.txt", "w", stdout);
int n;
scanf("%d", &n);
for(int i = 1; i < n; i ++) {
scanf("%d", &fa[i]);
ch[fa[i]].push_back(i);
}
for(int i = 1; i < n; i ++)
dep[i] = getdep(i);
int q;
scanf("%d", &q);
while(q --) {
int m, mnd = n + 1;
scanf("%d", &m);
vector<int> vec(m);
for(int i = 0; i < m; i ++) {
scanf("%d", &vec[i]);
mnd = min(mnd, dep[vec[i]]);
}
for (int i = n - 1; i >= 0; i --)
if (dep[i] <= mnd && check(i, n, vec)) {
printf("%d\n", i);
break ;
}
}
return 0;
}