算法学习笔记——专题拓展5:并查集(Union-find)算法

本文介绍了并查集(Union-Find)算法的概念及其在动态连通性问题上的应用,提供了四个实例(最大人工岛、被围绕的区域、等式方程可满足性),展示了如何使用模板代码实现和解决相关问题。

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

介绍

并查集(Union-Find)算法是一个专门针对「动态连通性」的算法,同时它也是最小生成树算法的前置知识。

模板代码

class UF{
    private:
        int count;
        int* parent;

    public:
        UF(int n){
            this->count = n;
            this->parent = new int[n];
            for(int i = 0; i<n; i++){
                parent[i] = i;
            }
        }

        void union(int p, int q){
            int rootP = find(p);
            int rootQ = find(q);
            if(rootP == rootQ){
                return;
            }
            parent[rootP] = rootQ;
            count--;
        }

        //使用了路径压缩,所以不需要size数组来平衡二叉树了
        int find(int x){
            if(parent[x] != x){
                parent[x] = find(parent[x]);
            }
            return parent[x];
        }

        bool connected(int p, int q){
            return find(p) == find(q);
        }

        int count(void){
            return count;
        }
}

题目

例题1:最大人工岛

分析

代码

例题2:被围绕的区域

分析

代码

例题3:等式方程的可满足性

分析

代码

例题4:

分析

代码

总结

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值