news 2026/4/12 3:29:42

信奥赛C++提高组csp-s之并查集(案例实践)3

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
信奥赛C++提高组csp-s之并查集(案例实践)3

信奥赛C++提高组csp-s之并查集(案例实践)3

题目描述

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

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

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

输入格式

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

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

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

  • 如果o p t optoptF,则表明p ppq qq是朋友。
  • 如果o p t optoptE,则表明p ppq qq是敌人。
输出格式

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

输入输出样例 #1
输入 #1
6 4 E 1 4 F 3 5 F 4 6 E 1 2
输出 #1
3
说明/提示

对于100 % 100\%100%的数据,2 ≤ n ≤ 1000 2 \le n \le 10002n10001 ≤ m ≤ 5000 1 \le m \le 50001m50001 ≤ p , q ≤ n 1 \le p,q \le n1p,qn

代码实现

#include<bits/stdc++.h>usingnamespacestd;intn,m;intfa[2010];// 并查集数组,大小为2n,用于处理朋友和敌人关系// 查找操作:找到x的根节点,并进行路径压缩intfind(intx){if(fa[x]!=x)fa[x]=find(fa[x]);returnfa[x];}// 合并操作:将x和y所在的集合合并voidunionSet(intx,inty){introotx=find(x);introoty=find(y);if(rootx==rooty)return;// 如果已经在同一集合,直接返回fa[rooty]=rootx;// 合并集合}intmain(){cin>>n>>m;// 初始化并查集,扩展i的虚拟结点i+n// i和i+n是敌对关系for(inti=1;i<=2*n;i++){fa[i]=i;}charc;intp,q;for(inti=1;i<=m;i++){cin>>c>>p>>q;if(c=='F'){// 朋友关系:直接合并unionSet(p,q);}else{// 敌人关系:// 将p与q+n合并(p与q的敌人是朋友)// 将q与p+n合并(q与p的敌人是朋友)// 这样实现了"敌人的敌人是朋友"的关系unionSet(p,q+n);unionSet(q,p+n);}}// 统计团体数量:只检查前n个节点(原始节点)intcnt=0;for(inti=1;i<=n;i++){if(fa[i]==i)cnt++;// 根节点数量即为团体数量}cout<<cnt;return0;}

功能分析

核心思路
  1. 朋友关系处理:直接合并两个节点
  2. 敌人关系处理:使用"反集"技巧
    • 如果p和q是敌人,那么:
      • p与q的敌人是朋友 → 合并p和q+n
      • q与p的敌人是朋友 → 合并q和p+n
算法原理
  • 使用扩展的并查集,大小为2n
  • 前n个节点(1~n)表示原始人物
  • 后n个节点(n+1~2n)表示"敌人的敌人"关系
  • 当两个人是敌人时,通过合并到对方的反集节点,间接实现了"敌人的敌人是朋友"的传递性
关键特性
  • 传递性:朋友的朋友是朋友,敌人的敌人是朋友
  • 对称性:如果p是q的敌人,那么q也是p的敌人
  • 反集技巧:通过创建虚拟节点来处理复杂的敌人关系

各种学习资料,助力大家一站式学习和提升!!!

#include<bits/stdc++.h>usingnamespacestd;intmain(){cout<<"########## 一站式掌握信奥赛知识! ##########";cout<<"############# 冲刺信奥赛拿奖! #############";cout<<"###### 课程购买后永久学习,不受限制! ######";return0;}
  • 一、CSP信奥赛C++通关学习视频课:
    • C++语法基础
    • C++语法进阶
    • C++算法
    • C++数据结构
    • CSP信奥赛数学
    • CSP信奥赛STL
  • 二、CSP信奥赛C++竞赛拿奖视频课:
    • 信奥赛csp-j初赛高频考点解析
    • CSP信奥赛C++复赛集训课(12大高频考点专题集训)
  • 三、csp高频考点知识详解及案例实践:
    • CSP信奥赛C++之动态规划
    • CSP信奥赛C++之标准模板库STL
    • 信奥赛C++提高组csp-s知识详解及案例实践
  • 四、考级、竞赛刷题题单及题解:
    • GESP C++考级真题题解
    • CSP信奥赛C++初赛及复赛高频考点真题解析
    • CSP信奥赛C++一等奖通关刷题题单及题解

详细内容:

1、csp/信奥赛C++,完整信奥赛系列课程(永久学习):

https://edu.csdn.net/lecturer/7901 点击跳转


2、CSP信奥赛C++竞赛拿奖视频课:

https://edu.csdn.net/course/detail/40437 点击跳转

3、csp信奥赛高频考点知识详解及案例实践:

CSP信奥赛C++动态规划:
https://blog.csdn.net/weixin_66461496/category_13096895.html点击跳转

CSP信奥赛C++标准模板库STL:
https://blog.csdn.net/weixin_66461496/category_13108077.html 点击跳转

信奥赛C++提高组csp-s知识详解及案例实践:
https://blog.csdn.net/weixin_66461496/category_13113932.html

4、csp信奥赛冲刺一等奖有效刷题题解:

CSP信奥赛C++初赛及复赛高频考点真题解析(持续更新):https://blog.csdn.net/weixin_66461496/category_12808781.html 点击跳转

CSP信奥赛C++一等奖通关刷题题单及题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12673810.html 点击跳转

5、GESP C++考级真题题解:

GESP(C++ 一级+二级+三级)真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12858102.html 点击跳转

GESP(C++ 四级+五级+六级)真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12869848.html 点击跳转

· 文末祝福 ·

#include<bits/stdc++.h>usingnamespacestd;intmain(){cout<<"跟着王老师一起学习信奥赛C++";cout<<" 成就更好的自己! ";cout<<" csp信奥赛一等奖属于你! ";return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/10 16:19:17

TegraRcmGUI完整教程:Switch注入技术终极指南

TegraRcmGUI完整教程&#xff1a;Switch注入技术终极指南 【免费下载链接】TegraRcmGUI C GUI for TegraRcmSmash (Fuse Gele exploit for Nintendo Switch) 项目地址: https://gitcode.com/gh_mirrors/te/TegraRcmGUI TegraRcmGUI是一款基于C开发的图形化注入工具&…

作者头像 李华
网站建设 2026/4/10 3:40:02

政治敏感话题检测利器:Qwen3Guard-Gen-8B实战表现优异

智能家居无线连接的稳定性挑战与MT7697芯片的应对之道 在智能家居设备日益普及的今天&#xff0c;用户对无线连接的稳定性、响应速度和功耗表现提出了越来越高的要求。无论是智能音箱、温控器还是安防摄像头&#xff0c;一旦出现断连、延迟或频繁重连&#xff0c;用户体验便会大…

作者头像 李华
网站建设 2026/4/11 21:49:03

2025网盘直链下载助手终极指南:免费解锁高速下载体验

2025网盘直链下载助手终极指南&#xff1a;免费解锁高速下载体验 【免费下载链接】Online-disk-direct-link-download-assistant 可以获取网盘文件真实下载地址。基于【网盘直链下载助手】修改&#xff08;改自6.1.4版本&#xff09; &#xff0c;自用&#xff0c;去推广&#…

作者头像 李华
网站建设 2026/4/11 15:07:30

绝区零效率革命:智能自动化助手的终极时间节省指南

绝区零效率革命&#xff1a;智能自动化助手的终极时间节省指南 【免费下载链接】ZenlessZoneZero-OneDragon 绝区零 一条龙 | 全自动 | 自动闪避 | 自动每日 | 自动空洞 | 支持手柄 项目地址: https://gitcode.com/gh_mirrors/ze/ZenlessZoneZero-OneDragon 还在为绝区零…

作者头像 李华
网站建设 2026/4/9 19:52:31

Kindle封面修复终极指南:一键解决电子书管理难题

Kindle封面修复终极指南&#xff1a;一键解决电子书管理难题 【免费下载链接】Fix-Kindle-Ebook-Cover A tool to fix damaged cover of Kindle ebook. 项目地址: https://gitcode.com/gh_mirrors/fi/Fix-Kindle-Ebook-Cover 当您精心收藏的Kindle电子书在设备上显示为灰…

作者头像 李华
网站建设 2026/4/11 18:45:56

青龙面板依赖终极解决方案:5分钟全自动安装指南

青龙面板依赖终极解决方案&#xff1a;5分钟全自动安装指南 【免费下载链接】QLDependency 青龙面板全依赖一键安装脚本 / Qinglong Pannel Dependency Install Scripts. 项目地址: https://gitcode.com/gh_mirrors/ql/QLDependency 还在为青龙面板的依赖问题而烦恼吗&a…

作者头像 李华