news 2025/12/16 19:52:39

洛谷P1551——亲戚(并查集入门)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
洛谷P1551——亲戚(并查集入门)

题目传送门

1.并查集是什么?

本质是一种树形结构(拥有相同根节点的多叉树),可以很方便的判断集合元素之间的从属关系。

2.如何维护好一个并查集?

并查集的本质在于相同的根节点,那么只需要通过某种方式记录好组内每一个元素的根节点,比较两个元素根节点是否相同就可以判断是否在同一个集合内。

3.如何判断根节点?

我们可以定义根节点的上一个节点为自己,这样子我们便有一个判断的条件了。

开始写代码吧。

头部分

#include<iostream> using namespace std; int fa[5010]; int main{ int a,b,c; cin>>a>>b>>c; int m,n; }

首先我们要初始化所有数的根为自身

for(int i=1;i<=a;i++){ fa[i]=i;//fa是father数组,记录其上一个节点信息 }

其次就是处理输入信息

我们要先读取两个整数,这两个整数是在同一个集合内的。

然后我们就要找他的根。

int find(int x){ while(x!=fa[x]){//循环找根节点(由根节点的定义 x=fa[x]; } return x;//返回找到的根节点 }

然后我们要统一两个数的根,这里我们可以想象一个图

a d

b b b e e e e e e e e e e e e

c c c c c c.

虽然有点丑,但是应该能看到这是一个三层和两层的树,我们要做的实际上是把他的根节点统一,即下图(如果这么丑也能算图的话):

a

b b b d

c c c c c c. e e e e e e e e e e e e

其实就是把一棵树全部(注意是全部)嫁接到另一棵树上。

for(int i=0;i<b;i++){ cin>>m>>n; if(find(m)!=find(n)) fa[find(m)]=find(n);//将一棵树的根节点插入到另一棵树上 }

然后就是判断是否相同了,很简单,直接贴完整代码了

#include<iostream> using namespace std; int fa[5010]; int find(int x){ while(x!=fa[x]){ x=fa[x]; } return x; } int main(){ int a,b,c; cin>>a>>b>>c; int m,n; for(int i=1;i<=a;i++){ fa[i]=i; } for(int i=0;i<b;i++){ cin>>m>>n; if(find(m)!=find(n)) fa[find(m)]=find(n); } for(int i=0;i<c;i++){ cin>>m>>n; if(find(m)==find(n)) printf("Yes\n"); else printf("No\n"); } return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/14 8:47:46

终极指南:3步解决Armbian音频配置难题

终极指南&#xff1a;3步解决Armbian音频配置难题 【免费下载链接】build Armbian Linux Build Framework 项目地址: https://gitcode.com/GitHub_Trending/bu/build 还在为单板计算机上的声音问题困扰吗&#xff1f;本文将为你提供完整的Armbian音频配置解决方案&#…

作者头像 李华
网站建设 2025/12/14 8:43:19

B站视频下载终极指南:5步轻松保存4K超清内容

B站视频下载终极指南&#xff1a;5步轻松保存4K超清内容 【免费下载链接】bilibili-downloader B站视频下载&#xff0c;支持下载大会员清晰度4K&#xff0c;持续更新中 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-downloader 还在为无法保存B站精彩视频而…

作者头像 李华
网站建设 2025/12/14 8:43:12

68.7%合成数据驱动,KORMo-10B如何重构韩语AI生态?

68.7%合成数据驱动&#xff0c;KORMo-10B如何重构韩语AI生态&#xff1f; 【免费下载链接】KORMo-10B-sft 项目地址: https://ai.gitcode.com/hf_mirrors/KORMo-Team/KORMo-10B-sft 导语 韩国KAIST团队发布的108亿参数全开源双语大模型KORMo-10B&#xff0c;以68.74%合…

作者头像 李华
网站建设 2025/12/14 8:41:36

开源LLM本地部署利器:Xinference如何实现90%成本节省?

开源LLM本地部署利器&#xff1a;Xinference如何实现90%成本节省&#xff1f; 【免费下载链接】inference Replace OpenAI GPT with another LLM in your app by changing a single line of code. Xinference gives you the freedom to use any LLM you need. With Xinference,…

作者头像 李华