C++ 并查集

在有些问题中我们需要维护若干个集合,并且基于这些集合要频繁的进行以下操作:

并查集(union find)

查询操作:查找一个元素x属于哪一个集合,一般会在每一个集合中选一个元素作为代表,查询的是这个集合中的代表元素

合并操作:将元素x所在的集合与元素y所在的元素合并成一个集合。(注意:合并的是这个集合中的所有元素,不是这两个元素)

判断操作:判断元素x和y是否在同一个集合

这些问题也可以用哈希表来解决 但是效率不高

const int N = 1e6 + 10;

int n;

int faN;

//初始化

void init()

{

//让其自己指向自己

for(int i = 1; i <= n; i++)

{

fai = i;

}

}

//查询操作 一直向上找爸爸 也就是找根节点

int find(int x)

{

//用简单的递归就能实现

if(fax == x) //说明就是根节点

return x;

return find(fax);

}

//合并 操作

void un(int x,int y)

{

//找x 和 y 的根节点是谁

int fx = find(x);

int fy = find(y);

//fx表示你所对应的根节点的编号,让其所对应的根节点的编号直接 等于fy

fafx = fy;

}

//判断元素x和y是否在同一集合

bool issame(int x,int y)

{

return find(x) == find(y);

}

int main()

{

return 0;

}

//优化操作 路径压缩

int find(int x)

{

if(fax == x)

return x;

return fax = find(fax);

}

相关推荐
云烟成雨TD5 小时前
Spring AI Alibaba 1.x 系列【69】Token 用量统计
java·人工智能·spring
Navigator_Z5 小时前
LeetCode //C - 1089. Duplicate Zeros
c语言·算法·leetcode
JAVA9655 小时前
JAVA面试-并发篇 03-使用synchronized doublecheck实现单例有什么坑
java·单例模式·面试
在繁华处5 小时前
Java从零到熟练(四):面向对象基础
java·开发语言
cany10005 小时前
C++ -- 可变参数模板
c++
不会C语言的男孩7 小时前
C++ Primer 第2章:变量和基本类型
开发语言·c++
小江的记录本7 小时前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
在繁华处7 小时前
Java从零到熟练(三):流程控制
java·开发语言·python
唐青枫7 小时前
Java Optional 实战指南:优雅处理空值与链式转换
java
一起学开源7 小时前
一文读懂 ReAct 范式:让 AI Agent 真正学会“思考+行动“
java·javascript·react.js·ecmascript·react·alibaba·智能体开发