当前位置: 首页 > article >正文

gesp(C++六级)(6)洛谷:P10109:[GESP202312 六级] 工作沟通

gesp(C++六级)(6)洛谷:P10109:[GESP202312 六级] 工作沟通

在这里插入图片描述

题目描述

某公司有 N N N 名员工,编号从 0 0 0 N − 1 N-1 N1。其中,除了 0 0 0 号员工是老板,其余每名员工都有一个直接领导。我们假设编号为 i i i 的员工的直接领导是 f i f_i fi

该公司有严格的管理制度,每位员工只能受到本人或直接领导或间接领导的管理。具体来说,规定员工 x x x 可以管理员工 y y y,当且仅当 x = y x=y x=y,或 x = f y x=f_y x=fy,或 x x x 可以管理 f y f_y fy。特别地, 0 0 0 号员工老板只能自我管理,无法由其他任何员工管理。

现在,有一些同事要开展合作,他们希望找到一位同事来主持这场合作,这位同事必须能够管理参与合作的所有同事。如果有多名满足这一条件的员工,他们希望找到编号最大的员工。你能帮帮他们吗?

输入格式

第一行一个整数 N N N,表示员工的数量。

第二行 N − 1 N - 1 N1 个用空格隔开的正整数,依次为 f 1 , f 2 , … f N − 1 f_1,f_2,\dots f_{N−1} f1,f2,fN1

第三行一个整数 Q Q Q,表示共有 Q Q Q 场合作需要安排。

接下来 Q Q Q 行,每行描述一场合作:开头是一个整数 m m m 2 ≤ m ≤ N 2 \le m \le N 2mN),表示参与本次合作的员工数量;接着是 m m m 个整数,依次表示参与本次合作的员工编号(保证编号合法且不重复)。

保证公司结构合法,即不存在任意一名员工,其本人是自己的直接或间接领导。

输出格式

输出 Q Q Q 行,每行一个整数,依次为每场合作的主持人选。

样例 #1

样例输入 #1

5
0 0 2 2
3
2 3 4
3 2 3 4
2 1 4

样例输出 #1

2
2
0

样例 #2

样例输入 #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 3,4 3,4 有共同领导 2 2 2 ,可以主持合作。

对于第二场合作,员工 2 2 2 本人即可以管理所有参与者。

对于第三场合作,只有 0 0 0 号老板才能管理所有员工。

数据范围

对于 50 % 50\% 50% 的测试点,保证 N ≤ 50 N \leq 50 N50

对于所有测试点,保证 3 ≤ N ≤ 300 3 \leq N \leq 300 3N300 Q ≤ 100 Q \leq 100 Q100


2024/1/28 添加一组 hack 数据。

AC代码(100分)

#include<bits/stdc++.h>
using namespace std;
/*思路: 
	找到每个的员工的全部领导,用数组标记
	如果某个人被标记了m次,这个人是所有人的公共领导
	如果有多个,输出编号最大的 	
*/
int n,f[310],q,m,x,cnt[310];//cnt是标记数组 
//函数:找一个员工的所有领导,并用数组标记 
void find(int x){
	cnt[x]++;//员工可以自己管理自己 
	while(x!=0){
		x=f[x];//向上找领导
		cnt[x]++; 
	} 
}
int main(){
	cin>>n;
	for(int i=1;i<=n-1;i++) cin>>f[i];
	cin>>q;
	while(q--){
		memset(cnt,0,sizeof(cnt));//多组测试,每次测试前初始化cnt数组 
		cin>>m;
		for(int i=1;i<=m;i++){
			cin>>x;
			find(x);//每输入一个数,找其所有领导,进行标记 
		}
		int ans;
		for(int i=n-1;i>=0;i--){//从后往前找 
			if(cnt[i]==m){//找到的第一个 
				ans=i;//就是编号最大的公共领导 
				break;
			}
		}
		cout<<ans<<endl;
	}
	return 0;
}

文末彩蛋:

点击王老师青少年编程主页有更多精彩内容


http://www.kler.cn/a/525079.html

相关文章:

  • 将ollama迁移到其他盘(eg:F盘)
  • postgres基准测试工具pgbench如何使用自定义的表结构和自定义sql
  • 【10.2】队列-设计循环队列
  • 30. C语言 动态内存管理详解:从malloc到realloc
  • 【PostgreSQL内核学习 —— (WindowAgg(一))】
  • ResNeSt: Split-Attention Networks论文学习笔记
  • C++ ——— 仿函数
  • 【2024年华为OD机试】(B卷,100分)- 模拟消息队列 (JavaScriptJava PythonC/C++)
  • FreeRTOS从入门到精通 第十三章(信号量)
  • Linux 信号驱动IO
  • 基于Springboot的健身房管理系统【附源码】
  • es6中关于let的使用以及案例,包括但不限于块级作用域,不允许重复声明,没有变量提升,暂存性死区,不与顶层对象挂钩
  • [SUCTF 2018]MultiSQL1
  • 微博热搜时光机逆向(js逆向)
  • 【力扣系列题目】最后一块石头的重量 分割回文串 验证回文串 等差数列划分{最大堆 背包 动态规划}
  • SSM总结
  • SpringBoot项目创建
  • 10.6.4 Json文件操作
  • RocketMQ原理—4.消息读写的性能优化
  • 高速PCB设计指南2——PCB设计的信号完整性
  • 【深度学习】softmax回归
  • Java—工具类类使用
  • 为什么机器学习中梯度下降是减去斜率,而不是按照其数学意义减去斜率的倒数
  • Java教程练习:学生信息管理系统
  • [STM32 - 野火] - - - 固件库学习笔记 - - -十三.高级定时器
  • 【AutoSar】汽车诊断标准协议UDS详解