【C++算法模板】并查集详解,一种处理不相交集合的合并与查询的数据结构

文章目录

0)概述

  • 并查集是用于处理不相交集合的合并与查询的树形数据结构

1)数据结构

  • 准备一个数组用于存储所有点的连通分量(父节点)
c 复制代码
const int maxn=2e5+5;
int fa[maxn];

2)核心函数

1:find函数

  • 用于查询某个顶点的父节点
c 复制代码
int find(int x) {
    if(x==fa[x])
        return x; // 如果本身就是父节点,返回本身
    else
        return fa[x]=find(fa[x]); // 递归压缩路径来查找父节点(降低时间复杂度)
}

2:join函数

  • 用于连接两个并查集
c 复制代码
void join(int a,int b) {
    fa[find(a)]=find(b); // b的父节点作为a原本的父节点的父节点
}

3)模板

  • 下列案例中:输入 1 1 2 1\ 1\ 2 1 1 2 表示把并查集 1 1 1 和 2 2 2 连接起来,输入 2 1 2 2\ 1\ 2 2 1 2 表示判断 1 1 1 和 2 2 2 是否属于同一并查集
  • 关键点:1)初始化时将每个节点的父节点初始化为自己;2)如果 a a a 和 b b b 的父节点相同,则表明二者处于同一并查集中
c 复制代码
#include<bits/stdc++.h>
using namespace std;
const int maxn=1e4+4;
int fa[maxn]; // 记录每个节点的父节点
int find(int x) {
	if(x==fa[x]) 
		return x;
	else
		// 路径压缩
		return fa[x]=find(fa[x]);
}
void join(int l,int r) {
	fa[find(l)]=find(r); // x的父节点的父节点变为y的父节点(合并)
}
int main() {
	int n,m;
	cin>>n>>m;
	int op,l,r; // op是操作,l和r是合并或判断关系的两个并查集
	// 1. 初始化每个结点的父节点都是自己
	for(int i=1;i<=n;i++) 
		fa[i]=i;
	while(m--) {
		cin>>op>>l>>r;
		if(op==1)
			join(l,r);
		else if(op==2) {
			if(find(l)==find(r)) // 在同一并查集中
				cout<<"Y\n";
			else
				cout<<"N\n";
		}
	}
	return 0;
}
  • 需要维护特定分量的并查集将在以后的博客中讲解
相关推荐
「QT(C++)开发工程师」1 分钟前
C++ 策略模式
开发语言·c++·策略模式
执着2595 分钟前
力扣hot100 - 108、将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
2501_901147837 分钟前
学习笔记:单调递增数字求解的迭代优化与工程实践
linux·服务器·笔记·学习·算法
数智工坊9 分钟前
【数据结构-特殊矩阵】3.5 特殊矩阵-压缩存储
数据结构·线性代数·矩阵
AI科技星10 分钟前
张祥前统一场论核心场方程的经典验证-基于电子与质子的求导溯源及力的精确计算
线性代数·算法·机器学习·矩阵·概率论
似霰14 分钟前
Linux timerfd 的基本使用
android·linux·c++
kebijuelun16 分钟前
ERNIE 5.0:统一自回归多模态与弹性训练
人工智能·算法·语言模型·transformer
芝士爱知识a21 分钟前
AlphaGBM 深度解析:下一代基于 AI 与蒙特卡洛的智能期权分析平台
数据结构·人工智能·python·股票·alphagbm·ai 驱动的智能期权分析·期权
兩尛26 分钟前
160. 相交链表/c++
数据结构·链表
三月微暖寻春笋29 分钟前
【和春笋一起学C++】(五十八)类继承
c++·派生类·类继承·基类构造函数·派生类构造函数