并查集入门(普通并查集+带删除并查集+关系并查集)

这篇博客介绍了并查集的概念,并详细讲解了普通并查集、带删除操作的并查集以及处理关系的并查集。通过实例和代码演示,帮助读者理解并查集在处理集合连接和断开关系时的实现方法。还特别提到了带删除操作时防止数组越界的问题。
摘要由CSDN通过智能技术生成

什么是并查集?通俗易懂的并查集详解

【普通并查集】

基础并查集(例题+题解)

【How Many Tables】

Problem Description

Lh Boy无聊的时候很喜欢数蚂蚁,而且,还给每一只小蚂蚁编号,通过他长期的观察和记录,发现编号为i的蚂蚁会和编号为j的蚂蚁在一起。
现在问题来了,他现在只有他的那本记录本,然而,他想要知道,他所观察的蚂蚁中,有多少堆蚁群。没有记录的编号则作为独自一个一堆。

Input

第一行输入一个整数T,表示有T(1<=T<=25)组测试案例。每一组测试案例,先输入两个整数N和M,分别表示蚂蚁的总数(编号分别为1~N)和记录的条数(1<=N,M<=1000)。紧接着有M行,每一行输入两个数字,a b,表示编号a和编号b的蚂蚁在同一堆里面。在每组测试案例之间都会输入一行空行。

Output

对于每组测试案例,在一行中输出答案。

【...】

跟之前相比区别在于Find函数写成递归的形式简短了很多(笑)。

【代码】

int pre[1005];
int Find(int x){return pre[x]==x?x:pre[x]=Find(pre[
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值