GESP编程共123题,本题是整站第1389题,已经有人完成了本题,加油!
某公司有 N 名员工,编号从 0 至 N−1。其中,除了 0 号员工是老板,其余每名员工都有一个直接领导。我们假设编号为 i 的员工的直接领导是 fi。
该公司有严格的管理制度,每位员工只能受到本人或直接领导或间接领导的管理。具体来说,规定员工 x 可以管理员工 y,当且仅当 x=y,或 x=fy,或 x 可以管理 fy。特别地,0 号员工老板只能自我管理,无法由其他任何员工管理。
现在,有一些同事要开展合作,他们希望找到一位同事来主持这场合作,这位同事必须能够管理参与合作的所有同事。如果有多名满足这一条件的员工,他们希望找到编号最大的员工。你能帮帮他们吗?
第一行一个整数 N,表示员工的数量。
第二行 N−1 个用空格隔开的正整数,依次为 f1,f2,…fN−1。
第三行一个整数 Q,表示共有 Q 场合作需要安排。
接下来 Q 行,每行描述一场合作:开头是一个整数 m(2≤m≤N),表示参与本次合作的员工数量;接着是 m 个整数,依次表示参与本次合作的员工编号(保证编号合法且不重复)。
保证公司结构合法,即不存在任意一名员工,其本人是自己的直接或间接领导。
输出 Q 行,每行一个整数,依次为每场合作的主持人选。
输入 #1
5 0 0 2 2 3 2 3 4 3 2 3 4 2 1 4
输出 #1
2 2 0
输入 #2
7 0 1 0 2 1 2 5 2 4 6 2 4 5 3 4 5 6 4 2 4 5 6 2 3 4
输出 #2
2 1 1 1 0
样例解释 1
对于第一场合作,员工3,4 有共同领导 2 ,可以主持合作。
对于第二场合作,员工 2 本人即可以管理所有参与者。
对于第三场合作,只有 0 号老板才能管理所有员工。
数据范围
对于 50% 的测试点,保证 N≤50。
对于所有测试点,保证 3≤N≤300,Q≤100。
【题目大意】0号是老板,一个人可以管理自己,管理直接下属,管理下属的下属。可以根据关系建立起树结构。现在要求有m个人自己组织会议,要找一个人主持会议。如果m个人中能主持就从m个人中选,不能就找上级领导,有多个选择,就求出最大的编号。注意,参会和主持的角色不一样。
【考纲知识点】循环知识,树结构,深搜,有根树
【解题思路】首先要建立树结构,根据父子关系,求出节点的结构,并求出对应的层数。针对每次查询,先看一下m个人中,层数最低的能不能主持会议,不能就从上级中选取,结果最小就是0号来主持。注意,要编号最大的,因此在筛选的时候从大到小去筛选。根据层中的第i个节点去判断能否访问到m中的每个孩子,如果是,那就可以主持。假设3和1都符合,也在同一层,但是倒序查找,找到3就退出了。符合最终答案。
【参考程序】
本站题目仅供学习,GESP版权归CCF所有,如有侵权请联系删除。站长陈老师QQ及微信:208234。