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

介绍

并查集(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:

分析

代码

总结

相关推荐

  1. Union-Find

    2024-04-26 07:58:03       15 阅读
  2. Union-Find)介绍

    2024-04-26 07:58:03       16 阅读
  3. c++算法学习笔记 (14)

    2024-04-26 07:58:03       19 阅读
  4. 算法实现

    2024-04-26 07:58:03       34 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-26 07:58:03       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-26 07:58:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-26 07:58:03       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-26 07:58:03       20 阅读

热门阅读

  1. Apache Flink 中作业图与执行图的深入解析

    2024-04-26 07:58:03       13 阅读
  2. [晕事]今天做了件晕事30, perf

    2024-04-26 07:58:03       10 阅读
  3. 华为NCE campus控制器及纳管设备清空配置

    2024-04-26 07:58:03       17 阅读
  4. R语言 数据的整理与清洗(Data Frame 篇下)

    2024-04-26 07:58:03       12 阅读
  5. 问答机器人学习资料

    2024-04-26 07:58:03       13 阅读
  6. 0054__【Linux】 sed命令详解

    2024-04-26 07:58:03       14 阅读
  7. 如何阻止事件冒泡和默认事件

    2024-04-26 07:58:03       11 阅读
  8. 使用Python进行自然语言处理:情感分析

    2024-04-26 07:58:03       11 阅读