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

题解:洛谷 P1892 [BalticOI 2003] 团伙

【题目来源】

洛谷:[P1892 BalticOI 2003] 团伙 - 洛谷

【题目描述】

现在有 \(n\) 个人,他们之间有两种关系:朋友和敌人。我们知道:

  • 一个人的朋友的朋友是朋友
  • 一个人的敌人的敌人是朋友

现在要对这些人进行组团。两个人在一个团体内当且仅当这两个人是朋友。请求出这些人中最多可能有的团体数。

【输入】

第一行输入一个整数 \(n\) 代表人数。

第二行输入一个整数 \(m\) 表示接下来要列出 \(m\) 个关系。

接下来 \(m\) 行,每行一个字符 \(opt\) 和两个整数 \(p,q\),分别代表关系(朋友或敌人),有关系的两个人之中的第一个人和第二个人。其中 \(opt\) 有两种可能:

  • 如果 \(opt\)F,则表明 \(p\)\(q\) 是朋友。
  • 如果 \(opt\)E,则表明 \(p\)\(q\) 是敌人。

【输出】

一行一个整数代表最多的团体数。

【输入样例】

6
4
E 1 4
F 3 5
F 4 6
E 1 2

【输出样例】

3

【解题思路】

image

【算法标签】

《洛谷 P1892 团伙》 #并查集# #2003#

【代码详解】

#include <bits/stdc++.h>
using namespace std;int n, m, x, y, ans;  // n: 人数, m: 关系数, x,y: 临时变量, ans: 结果
int p[2005];         // 并查集父节点数组(开两倍空间处理敌对关系)/*** 查找根节点(带路径压缩)* @param x 当前节点* @return 根节点*/
int find(int x)
{return p[x] == x ? x : p[x] = find(p[x]);
}/*** 合并两个集合* @param x 第一个节点* @param y 第二个节点*/
void merge(int x, int y) 
{p[find(y)] = find(x);
}int main()
{// 输入人数和关系数cin >> n >> m;// 初始化并查集(前n个表示本人,后n个表示敌人)for (int i = 1; i <= 2 * n; i++) {p[i] = i;}// 处理每条关系for (int i = 1; i <= m; i++) {char ch;cin >> ch >> x >> y;if (ch == 'F') {// 朋友关系直接合并merge(x, y);} else {// 敌人关系:x与y的敌人是朋友merge(x, y + n);// y与x的敌人是朋友merge(y, x + n);}}// 统计集合个数(只统计前n个节点)for (int i = 1; i <= n; i++) {if (p[i] == i) {ans++;}}// 输出结果cout << ans;return 0;
}

【运行结果】

6
4
E 1 4
F 3 5
F 4 6
E 1 2
3
http://www.jsqmd.com/news/391975/

相关文章:

  • 计算机视觉opencv之金字塔直方图 - 详解
  • 题解:洛谷 P1229 遍历问题
  • 百联OK卡回收攻略:快速实现交易,解决常见问题 - 团团收购物卡回收
  • 西门子 博图V15洁净室温湿度串级控制结构化编程 使用串级PID的方式控制空调的回风,送风的温...
  • 英语_作文练习_Curiosity Leads Me_待读
  • 题解:洛谷 P5266 【深基17.例6】学籍管理
  • 题解:洛谷 P1918 保龄球
  • 2026评价好的接线防爆箱供应商怎么选?秘籍大揭秘,住宅配电柜/高压配电柜/金属封闭高压柜,防爆箱厂家怎么选择 - 品牌推荐师
  • 2026金相镶嵌机供应商推荐,性能稳定更可靠,单点加力金相磨抛机/试验机/电动洛氏硬度计,金相镶嵌机企业找哪家 - 品牌推荐师
  • 永辉超市卡怎么回收?实用技巧让你不再浪费! - 团团收购物卡回收
  • COMSOL仿真研究:单个金纳米颗粒光热效应的复现与波动光学、固体传热机理的探索
  • YOLOv12 改进 | Backbone改进 2
  • 生产环境【大模型学习】提示词工程(Prompt Engineering)技术深度报告最佳实践与性能优化
  • 学习笔记:连续子数组和问题的优化思路与工程实现思考
  • 学习笔记:二进制数组中0和1数量相等的最长连续子数组——从常规解法到性能优化
  • 量子网络:从理论到工程化探索
  • 分期乐购物额度回收平台推荐:省钱、省力的优选方法 - 团团收购物卡回收
  • PNG 转 JPG 在线工具推荐:免费、批量、无需注册的实用网站整理
  • 深入解析:基于机器学习的农产品价格数据分析与预测系统
  • 定稿前必看!10个降AIGC工具:继续教育降AI率全测评
  • 超级老龄化科技社会
  • 把vlm专门识别屏幕加入历史对话记录上下文中,​然后llm每两分钟参考历史记录对话这样效果好吗
  • 少走弯路:千笔AI,研究生降重首选利器
  • 脚本之轻 vs 程序之重:深度解析3DSMax两大插件生态的优劣与抉择 - 实践
  • 加油卡回收流程揭秘:平台选择与避坑技巧全解析 - 团团收购物卡回收
  • 详细介绍:P14978 [USACO26JAN1] Mooclear Reactor S题解
  • 硕士论文5万字AI率太高怎么办?大论文降AI全攻略
  • 文科生论文AI率特别高?原因和解决方案都在这了
  • 2070年人口数量可能降低一半,剩下7亿人。采用AI + 机器人来应对的可能和可行性有多大?
  • 永辉超市卡快速回收:如何找到高价回收平台 - 团团收购物卡回收