总结并查集

并查集是一种数据结构,用于处理不相交集合的合并与查询。通过父节点代表集合,支持合并(Union)和查询(Find)操作。初始化时每个元素自成集合,查询时使用路径压缩提高效率,合并则连接两个集合的根节点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

并查集(指针向上的树)的重要思想是用集合中的一个元素(父节点)代表集合,主要用于解决一些元素分组的问题。管理一系列不相交的集合,并支持两种操作:

  1. 合并(Union):把两个不相交的集合合并为一个集合
  2. 查询(Find):查询两个元素是否在同一个集合中,或者查询节点的父节点,通过比较两个父节点是否相同来判断是否在同一个集合
#define MAXN 10000
// 初始化:初始时,每个元素自成集合
vector<int> fa(MAXN);
void init(int n) {
	for (int i = 0; i < n; i++) {
		fa[i] = i;
	}
}
// 查询:查找i号元素的父节点的编号
int findFather(int i) {
	if (fa[i] == i) { return i; }
	fa[i] = findFather(fa[i]);// 路径压缩
	return fa[i];
}
// 合并:合并i号元素和j号元素所在的集合
void unionSet(int i, int j) {
	if (fa[i] == fa[j]) { return; }
	int fatherOfI = findFather(i);
	int fatherOfJ = findFather(j);
	fa[fatherOfI] = fatherOfJ;
}

参考:
https://zhuanlan.zhihu.com/p/93647900

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值