news 2026/1/16 11:04:38

信奥赛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/1/16 18:26:12

突破网盘限速壁垒:直链下载助手的全方位应用指南

突破网盘限速壁垒&#xff1a;直链下载助手的全方位应用指南 【免费下载链接】Online-disk-direct-link-download-assistant 可以获取网盘文件真实下载地址。基于【网盘直链下载助手】修改&#xff08;改自6.1.4版本&#xff09; &#xff0c;自用&#xff0c;去推广&#xff0…

作者头像 李华
网站建设 2026/1/16 12:55:10

Jable视频高效下载解决方案:一键保存m3u8流媒体内容

Jable视频高效下载解决方案&#xff1a;一键保存m3u8流媒体内容 【免费下载链接】jable-download 方便下载jable的小工具 项目地址: https://gitcode.com/gh_mirrors/ja/jable-download 还在为无法离线观看Jable.tv平台的精彩内容而困扰吗&#xff1f;这款专业的Jable视…

作者头像 李华
网站建设 2026/1/12 10:30:55

突破网盘限速壁垒:极速下载完整实战指南

突破网盘限速壁垒&#xff1a;极速下载完整实战指南 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 还在为网盘下载速度慢如蜗牛而烦恼&#xff1f;当你急需重要文件&#xff0c;却要面对几十KB的下载速…

作者头像 李华
网站建设 2026/1/14 23:24:58

城通网盘解析工具:告别下载限速的简单方法

城通网盘解析工具&#xff1a;告别下载限速的简单方法 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 你是否曾经遇到过这样的情况&#xff1a;急需下载城通网盘中的文件&#xff0c;却发现下载速度慢得…

作者头像 李华
网站建设 2026/1/16 15:07:09

城通网盘下载加速终极教程:告别限速的完整解决方案

城通网盘下载加速终极教程&#xff1a;告别限速的完整解决方案 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 还在为城通网盘几十KB的下载速度而苦恼吗&#xff1f;当你急需某个重要文件&#xff0c;却…

作者头像 李华
网站建设 2026/1/14 23:26:24

城通网盘下载效率优化工具:告别限速等待的智能解决方案

城通网盘下载效率优化工具&#xff1a;告别限速等待的智能解决方案 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 城通网盘作为常用的文件分享平台&#xff0c;其下载限速问题一直是用户面临的困扰。传…

作者头像 李华