题目描述
总共有 n 个人在机房,每个人有一个标号(1<=标号<=n),他们分成了多个团队,
需要你根据收到的 m 条消息判定指定的两个人是否在一个团队中,具体的:
消息构成为 a b c,整数 a、b 分别代表两个人的标号,整数 c 代表指令
c == 0 代表 a 和 b 在一个团队内
c == 1 代表需要判定 a 和 b 的关系,如果 a 和 b 是一个团队,输出一行’we are a team’,如果不是,输出一行’we are not a team’
c 为其他值,或当前行 a 或 b 超出 1~n 的范围,输出‘da pian zi’
输入描述
第一行包含两个整数 n,m(1<=n,m<100000),分别表示有 n 个人和 m 条消息
随后的 m 行,每行一条消息,消息格式为:a b c(1<=a,b<=n,0<=c<=1)
输出描述
c ==1,根据 a 和 b 是否在一个团队中输出一行字符串,在一个团队中输出‘we are a team‘,
不在一个团队中输出’we are not a team’
c 为其他值,或当前行 a 或 b 的标号小于 1 或者大于 n 时,输出字符串‘da pian zi‘
如果第一行 n 和 m不符合题目要求的范围,输出"NULL"
示例1
输入
5 7
【华为OD机试c++】We are a team(C++ Python Java)2023 B卷
这是一个关于华为在线开发者(OD)机试题目的解析,题目要求根据输入的消息判断团队成员关系。给定团队成员的编号和一系列指令,当指令c为0时表示两个编号在同一团队,为1时需要判断他们是否在同一团队。输入包括团队人数n和消息数量m,以及m条消息。解题策略是使用并查集数据结构。示例展示了不同指令下的输出结果。
订阅专栏 解锁全文

被折叠的 条评论
为什么被折叠?



