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

洛谷 P1892 [BalticOI 2003] 团伙 简单并查集 做法 题解

题目描述:

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

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

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

输入格式

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

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

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

  • 如果 opt 为F,则表明 p 和 q 是朋友。
  • 如果 opt 为E,则表明 p 和 q 是敌人。

输出格式

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

输入输出样例

输入 #1复制

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

输出 #1复制

3

说明/提示

对于 100% 的数据,2≤n≤1000,1≤m≤5000,1≤p,q≤n。

思路:

题目简单来说就是给出几对关系,有朋友关系也有敌对关系,要我们输出最终团体的数量。看到这种说两两关系的题我们可以想到用并查集来做,按题目的说法我们可以知道朋友的敌人的朋友就是敌人,敌人的敌人是朋友,都是朋友说明在一个团体。那么我们可以考虑扩展两倍n,做一个虚拟节点(n+1~2n)的操作,一半朋友,一半敌人,也就是n*2。然后是朋友就正常合并他们为一个团体(合并(x,y)),否则就是敌对,那么有"一对"关系,也就是x讨厌y,y讨厌x,那么我们可以进行两个合并,即合并(x+n,y),合并(y+n,x)。最后统计1到n的根节点数量,也就是团体数量,也就是答案。

举个例子:

假设n=2m=1,操作是E 1 2(1 和 2 是敌人)。

  1. 初始化:saki[1]=1, saki[2]=2, saki[3]=3, saki[4]=4
  2. 执行he(1+2, 2)he(3, 2),此时saki[fin(3)] = fin(2)saki[2] = 2(3 的根变成 2)
  3. 执行he(2+2, 1)he(4, 1),此时saki[fin(4)] = fin(1)saki[1] = 1(4 的根变成 1)

主播的代码(参考):

#include <iostream> #include<queue> #include<algorithm> #include<map> #include<vector> #include<set> #include<stack> #include<string> #include<math.h> #include <iomanip> #include<unordered_map> #include <unordered_set> #include<array> #define gets(S) fgets(S,sizeof(S),stdin) #define ll long long const ll N = 1e6 + 5; const ll Max = 0x3f3f3f3f; using namespace std; ll n, m, saki[N]; ll fin(ll x) { return saki[x] == x ? x : saki[x] = fin(saki[x]); } void he(ll x, ll y) { saki[fin(x)] = fin(y); } int main() { cin >> n >> m; for (int i = 1; i <= n * 2; i++) { saki[i] = i; } char c; ll x, y; for (int i = 1; i <= m; i++) { cin >> c; cin >> x >> y; if (c == 'F') { he(x, y); } else { he(x + n, y); he(y + n, x); } } ll ans = 0; for (int i = 1; i <= n; i++) { if (fin(i) == i) { ans++; } } cout << ans; return 0; }
http://www.jsqmd.com/news/102155/

相关文章:

  • Realm端口转发教程
  • 商业模式画布填充:LobeChat理清商业逻辑
  • LobeChat制造业知识库查询终端部署案例
  • 电路中mos管的作用
  • 计算机Java毕设实战-基于javaWEB的餐厅后勤管理系统的设计与实现基于javaWEB的饭馆餐厅后勤管理系统的设计与实现【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 计算机Java毕设实战-基于Java的仓库管理系统设计与实现基于Java+SpringBoot+Vue仓库管理系统的设计与实现【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 计算机Java毕设实战-基于Java+SpringBoot+Vue的畅销图书推荐系统基于java的畅销图书推荐系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 计算机Java毕设实战-基于JavaWeb的心聘求职平台的设计与实现基于springboot的人才求职招聘平台设计与实现【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 计算机Java毕设实战-基于JavaWeb的家装一体化平台室内设计、装修施工、建材选购【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 计算机Java毕设实战-基于javaweb的宠物托管系统基于springboot+vue的宠物托管系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 计算机Java毕设实战-基于javaweb的在线图书借阅管理系统图书馆在线借阅管理系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 计算机Java毕设实战-基于JavaWeb的兽医站管理系统的设计与实现动物医院管理系统的设计与实现【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 大数据领域数据增强:挖掘数据潜力的秘诀
  • Java 并发编程之 ThreadPoolExecutor 深度解析:从原理到实战
  • 智能体间博弈理论在价值投资策略优化中的应用
  • 巴菲特的投资观察与启示
  • 芒格的“反向工程“思维在量子密码破解防御中的应用
  • Python面向对象——进阶(三)
  • CosyVoice3 - 跨语言、会方言、懂情绪的智能配音工具 文本转语音 语音克隆 支持50系显卡 一键整合包下载
  • 四季梅豆角矮砧密植:水肥一体化系统的铺设要点
  • 【LLM基础教程】从序列切分到上下文窗口02_三种数据切分方法
  • 9 个高效降AI率工具,自考人必备!
  • 【LLM基础教程】LLM训练数据集是如何构造的:从文档到Token Block
  • 8 个降AI率工具推荐,本科生高效避坑指南
  • 打表小技巧
  • 10个降AI率工具,专科生高效避坑指南
  • 8 个降AI率工具,自考学生高效避坑指南
  • SQL中的NULL值处理技巧
  • AI绘画商业化落地:图像生成应用的7个盈利模式
  • LobeChat与知识库系统联动:构建智能问答闭环