代码随想录|图论|15并查集理论基础

并查集理论基础 | 代码随想录

并查集还是比较简单的,只要搞清楚两个事情:

  1. 并查集是干啥的?解决什么类型问题?
  2. 并查集模板(背下来)

1、并查集是干啥的

并查集主要是两个功能:

  1. 两个元素添加到同一集合。
  2. 判断两个元素是否在同一集合

所以就是合并跟查找。

2、并查集模板

模版就是定义4个函数:

  1. 初始化
  2. 寻根(优化版更快)
  3. 判断
  4. 合并
cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int n=1005;
vector<int> father(n,0);    // 根数组



// 并查集初始化
void init()
{
    for(int i=0;i<n;i++)
    {
        father[i]=i;
    }
}

// 并查集寻根
int find(int u)
{
    if(u=father[u])
        return u;
    else
        return find(father[u]);
}

// 并查集寻根(优化版)
int find(int u)
{
    if(u==father[u]) return u;
    else return father[u]=find(father[u]);
}


// 判断u和v是否在一个集合里面
bool isSame(int u,int v)
{
    u=find(u);
    v=find(v);
    return u==v;
}

// 将两个元素添加到同一个集合里
void join(int u,int v)
{
    u=find(u);
    v=find(v);
    if(u==v) return;    // 如果根相同,则说明在一个集合
    father[u]=v;
}
相关推荐
十八岁讨厌编程1 小时前
【算法训练营Day26】动态规划part2
算法·动态规划
智者知已应修善业2 小时前
【C++无数组矩阵对角线平均值保留2位小数】2022-11-18
c语言·c++·经验分享·笔记·算法·矩阵
papership2 小时前
【入门级-算法-6、排序算法: 计数排序】
数据结构·算法·排序算法
pengpeng022 小时前
力扣每日一题 611. 有效三角形的个数
算法·leetcode·职场和发展
2401_840105203 小时前
GESP C++5级 2025年6月编程2题解:最大公因数
数据结构·c++·算法
未知陨落3 小时前
LeetCode:56.子集
算法·leetcode·深度优先
PAK向日葵3 小时前
【算法导论】一道涉及到溢出处理的笔试题
算法·面试
哈泽尔都4 小时前
运动控制教学——5分钟学会样条曲线算法!(三次样条曲线,B样条曲线)
c++·人工智能·算法·机器学习·matlab·贪心算法·机器人
小镇学者4 小时前
【NOI】在信奥赛中 什么是函数交互题?
算法
未知陨落4 小时前
LeetCode:62.N皇后
算法·leetcode