news 2026/5/14 17:46:59

2025年9月GESP真题及题解(C++七级): 连通图

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
2025年9月GESP真题及题解(C++七级): 连通图

2025年9月GESP真题及题解(C++七级): 连通图

题目描述

给定一张包含n nn个结点与m mm条边的无向图,结点依次以1 , 2 , … , n 1,2,\ldots,n1,2,,n编号,第i ii条边(1 ≤ i ≤ m 1\le i\le m1im)连接结点u i u_iui与结点v i v_ivi。如果从一个结点经过若干条边可以到达另一个结点,则称这两个结点是连通的。

你需要向图中加入若干条边,使得图中任意两个结点都是连通的。请你求出最少需要加入的边的条数。

注意给出的图中可能包含重边与自环。

输入格式

第一行,两个正整数n , m n,mn,m,表示图的点数与边数。

接下来m mm行,每行两个正整数u i , v i u_i,v_iui,vi,表示图中一条连接结点u i u_iui与结点v i v_ivi的边。

输出格式

输出一行,一个整数,表示使得图中任意两个结点连通所需加入的边的最少数量。

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

对于40 % 40\%40%的测试点,保证1 ≤ n ≤ 100 1\le n\le 1001n1001 ≤ m ≤ 100 1\le m\le 1001m100

对于所有测试点,保证1 ≤ n ≤ 10 5 1\le n\le 10^51n1051 ≤ m ≤ 10 5 1\le m\le 10^51m105

思路分析

这是一个连通分量计数问题。要让整个图连通,我们需要将图中所有连通分量连接起来。

关键点:
  1. 如果图已经是连通的(只有1个连通分量),则不需要加边 → 答案为0
  2. 如果有k个连通分量,最少需要k-1条边将它们连接成连通图
  3. 重边和自环不影响连通性判断
解题步骤:
  1. 使用**并查集(Union-Find)**统计连通分量数量
  2. 答案 = 连通分量数量 - 1
复杂度分析:
  • 并查集:O(m·α(n)),其中α是反阿克曼函数,近似常数
  • DFS/BFS:O(n + m)
  • 本题n,m ≤ 10^5,两种方法都可行

代码实现

#include<bits/stdc++.h>usingnamespacestd;constintMAXN=100005;// 并查集数组intparent[MAXN];intsize[MAXN];// 初始化并查集voidinit(intn){for(inti=1;i<=n;i++){parent[i]=i;// 每个节点的父节点初始为自己size[i]=1;// 每个集合的大小初始为1}}// 查找根节点(带路径压缩)intfind(intx){if(parent[x]!=x){parent[x]=find(parent[x]);// 路径压缩,直接指向根节点}returnparent[x];}// 合并两个节点所在的集合(按秩合并)voidunite(intx,inty){introotX=find(x);introotY=find(y);// 如果已经在同一集合,无需合并if(rootX==rootY)return;// 按大小合并:将小集合合并到大集合if(size[rootX]<size[rootY]){parent[rootX]=rootY;size[rootY]+=size[rootX];}else{parent[rootY]=rootX;size[rootX]+=size[rootY];}}intmain(){ios::sync_with_stdio(false);cin.tie(0);intn,m;cin>>n>>m;// 初始化并查集init(n);// 处理每条边for(inti=0;i<m;i++){intu,v;cin>>u>>v;unite(u,v);// 合并两个节点所在的连通分量}// 统计连通分量数量intcomponents=0;for(inti=1;i<=n;i++){// 如果节点的父节点是自己,说明它是一个连通分量的根if(parent[i]==i){components++;}}// 需要添加的边数 = 连通分量数 - 1cout<<components-1<<endl;return0;}

功能分析

数据结构:
  • parent[i]: 存储节点i的父节点
  • size[i]: 存储以i为根的集合大小(用于按秩合并)
核心函数:
  1. init(n):

    • 初始化并查集
    • 每个节点自成一个集合
  2. find(x):

    • 查找x所在集合的根节点
    • 使用路径压缩优化:将查询路径上的节点直接指向根节点
    • 均摊时间复杂度O(α(n)),近似常数
  3. unite(x, y):

    • 合并x和y所在的集合
    • 使用按大小合并优化:将小集合合并到大集合
    • 避免树退化成链,保证查询效率
主流程:
  1. 读取n和m
  2. 初始化并查集
  3. 逐条边读入并合并两个端点所在的连通分量
    • 注意:重边和自环会被unite函数正确处理(自环的u==v会直接返回,重边会重复合并同一集合)
  4. 统计连通分量数量
    • 遍历所有节点,统计根节点数量(parent[i]==i)
  5. 输出结果:components - 1
复杂度:
  • 时间复杂度:O(m·α(n) + n),其中α(n)是反阿克曼函数,非常小(≤5)
  • 空间复杂度:O(n)
示例验证:

示例1

输入: 4 4 1 2 2 3 3 1 1 4
  • 所有节点连通 → 1个连通分量
  • 答案 = 1 - 1 = 0

示例2

输入: 6 4 1 2 2 3 3 1 6 5
  • 连通分量1:{1,2,3}
  • 连通分量2:{4}(孤立节点)
  • 连通分量3:{5,6}
  • 共3个连通分量
  • 答案 = 3 - 1 = 2

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

#include<bits/stdc++.h>usingnamespacestd;intmain(){cout<<"########## 一站式掌握信奥赛知识! ##########";cout<<"############# 冲刺信奥赛拿奖! #############";cout<<"###### 课程购买后永久学习,不受限制! ######";return0;}

1、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

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

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

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

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

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

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


GESP(C++ 七级+八级)真题题解(持续更新):
https://blog.csdn.net/weixin_66461496/category_13117178.html

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

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

· 文末祝福 ·

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

IndexTTS2使用避坑贴士:这些错误千万别再犯了

IndexTTS2使用避坑贴士&#xff1a;这些错误千万别再犯了 在部署和使用IndexTTS2的过程中&#xff0c;许多开发者常常因为一些看似微不足道的操作失误&#xff0c;导致服务无法启动、模型加载失败甚至系统资源耗尽。本文将结合实际工程经验&#xff0c;梳理出最常见且极具破坏…

作者头像 李华
网站建设 2026/5/10 8:36:00

4步完整解锁Windows远程桌面多用户专业配置

4步完整解锁Windows远程桌面多用户专业配置 【免费下载链接】rdpwrap RDP Wrapper Library 项目地址: https://gitcode.com/gh_mirrors/rd/rdpwrap 还在为Windows系统只能支持单个远程连接而困扰吗&#xff1f;远程桌面多用户限制是许多用户在日常工作中遇到的常见问题&…

作者头像 李华
网站建设 2026/5/7 19:28:14

AnimeGANv2教程:如何自定义动漫风格效果

AnimeGANv2教程&#xff1a;如何自定义动漫风格效果 1. 引言 随着深度学习技术的发展&#xff0c;AI驱动的图像风格迁移逐渐走入大众视野。其中&#xff0c;AnimeGANv2 作为专为“照片转二次元动漫”设计的生成对抗网络&#xff08;GAN&#xff09;模型&#xff0c;因其出色的…

作者头像 李华
网站建设 2026/4/28 3:48:01

MusicFree插件使用指南

MusicFree插件使用指南 【免费下载链接】MusicFreePlugins MusicFree播放插件 项目地址: https://gitcode.com/gh_mirrors/mu/MusicFreePlugins 想要在一个应用中畅享全网免费音乐&#xff1f;MusicFree插件系统就是你的完美选择&#xff01;这个强大的插件生态让你无需…

作者头像 李华
网站建设 2026/5/8 8:24:55

如何快速配置Hanime1Plugin:Android观影体验的完整指南

如何快速配置Hanime1Plugin&#xff1a;Android观影体验的完整指南 【免费下载链接】Hanime1Plugin Android插件(https://hanime1.me) (NSFW) 项目地址: https://gitcode.com/gh_mirrors/ha/Hanime1Plugin 在Android设备上享受高质量的视频内容已经成为现代生活的常态&a…

作者头像 李华
网站建设 2026/5/12 19:59:42

纪念币预约终极方案:告别手忙脚乱的智能抢购神器

纪念币预约终极方案&#xff1a;告别手忙脚乱的智能抢购神器 【免费下载链接】auto_commemorative_coin_booking 项目地址: https://gitcode.com/gh_mirrors/au/auto_commemorative_coin_booking 还在为每次纪念币预约的激烈竞争而焦虑吗&#xff1f;传统手动预约方式往…

作者头像 李华