news 2026/6/10 15:44:59

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
洛谷 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; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 12:48:14

10 个高效降AI率工具,本科生必备神器!

10 个高效降AI率工具&#xff0c;本科生必备神器&#xff01; AI降重工具&#xff1a;论文写作的得力助手 在当今学术写作中&#xff0c;随着AI生成内容&#xff08;AIGC&#xff09;的广泛应用&#xff0c;越来越多的本科生面临一个共同的问题——如何有效降低论文中的AI痕迹和…

作者头像 李华
网站建设 2026/6/10 13:33:28

Java毕设选题推荐:基于springboot的自习室座位预约系统基于javaweb的自习室座位管理系统【附源码、mysql、文档、调试+代码讲解+全bao等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/6/10 13:31:48

计算机Java毕设实战-基于Java+SpringBoot+Vue的电子印章管理系统基于JavaEE的电子印章管理系统的设计与实现【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/6/10 13:31:28

电路中mos管的作用

MOS管在电路中的核心作用是以极低的驱动功率&#xff0c;精确控制大功率电能的流动与转换&#xff0c;实现信号放大、高速开关、电能变换和系统保护四大功能。其电压控制特性使其成为现代电子电路的"智能电闸"&#xff0c;从根本上改变了功率电子的设计范式。一、开关…

作者头像 李华
网站建设 2026/6/9 16:14:24

高级搜索模块 Cordova 与 OpenHarmony 混合开发实战

&#x1f4cc; 概述 高级搜索模块提供了多条件搜索喝茶记录的功能。该模块集成了 Cordova 框架与 OpenHarmony 原生能力&#xff0c;允许用户按日期范围、茶叶类型、产地、价格范围和评分等多个条件进行搜索。模块支持条件组合搜索&#xff0c;提供了强大的数据查询能力。用户…

作者头像 李华
网站建设 2026/6/10 5:03:16

LobeChat人力资源政策起草助手

LobeChat构建人力资源政策起草助手的技术实践 在企业数字化转型的浪潮中&#xff0c;人力资源部门正面临前所未有的挑战&#xff1a;如何在合规的前提下&#xff0c;高效制定和更新日益复杂的管理制度&#xff1f;传统的文档撰写方式不仅耗时费力&#xff0c;还容易因法规理解…

作者头像 李华