并查集快速查找(Java 实例代码)

news/2024/11/25 4:41:01/

目录

 

并查集快速查找

Java 实例代码

UnionFind1.java 文件代码:


 

并查集快速查找

本小节基于上一小节并查集的结构介绍基础操作,查询和合并和判断是否连接。

查询元素所在的集合编号,直接返回 id 数组值,O(1) 的时间复杂度。

...
private int find(int p) {
    assert p >= 0 && p < count;
    return id[p];
}
...

合并元素 p 和元素 q 所属的集合, 合并过程需要遍历一遍所有元素, 再将两个元素的所属集合编号合并,这个过程是 O(n) 复杂度。

...
public void unionElements(int p, int q) {
    int pID = find(p);
    int qID = find(q);
    if (pID == qID)
        return;
    for (int i = 0; i < count; i++)
        if (id[i] == pID)
            id[i] = qID;
}
...

Java 实例代码

源码包下载:Download

UnionFind1.java 文件代码:

package runoob.union;

/**
 * 第一版union-Find
 */
public class UnionFind1 {
    // 我们的第一版Union-Find本质就是一个数组
    private int[] id;
    // 数据个数
    private int count;

    public UnionFind1(int n) {
        count = n;
        id = new int[n];
        // 初始化, 每一个id[i]指向自己, 没有合并的元素
        for (int i = 0; i < n; i++)
            id[i] = i;
    }

    // 查找过程, 查找元素p所对应的集合编号
    private int find(int p) {
        assert p >= 0 && p < count;
        return id[p];
    }

    // 查看元素p和元素q是否所属一个集合
    // O(1)复杂度
    public boolean isConnected(int p, int q) {
        return find(p) == find(q);
    }

    // 合并元素p和元素q所属的集合
    // O(n) 复杂度
    public void unionElements(int p, int q) {

        int pID = find(p);
        int qID = find(q);

        if (pID == qID)
            return;

        // 合并过程需要遍历一遍所有元素, 将两个元素的所属集合编号合并
        for (int i = 0; i < count; i++)
            if (id[i] == pID)
                id[i] = qID;
    }
}

 


http://www.ppmy.cn/news/1109011.html

相关文章

后端字典的优雅设计

背景 今天讲到的是数据字典的设计。为什么要讲到这个呢&#xff0c;因为我下午在做开发的时候遇到了一个问题。我先扔出来某个表的字段的定义吧&#xff1a; business_type int default 0 comment 0&#xff1a;收款计划&#xff1b;1&#xff1a;付款计划而且我还有一个字典…

Python---匿名函数 lambda

匿名函数 ---- lambda (不能重复使用) 匿名函数定义语法:lambda 传入参数: 函数体(一行代码) lambda 是关键字&#xff0c;表示定义匿名函数 传入参数表示匿名函数的形式参数&#xff0c;如:xy表示接收2个形式参数函数体&#xff0c;就是函数的执行逻辑&#xff0c;要注意:只能…

c、c++、java、python、js对比【面向对象、过程;解释、编译语言;封装、继承、多态】

C 手动内存管理&#xff1a;C语言没有内置的安全检查机制&#xff0c;容易出现内存泄漏、缓冲区溢出等安全问题。 适用于系统级编程 C 手动内存管理&#xff1a;C需要程序员手动管理内存&#xff0c;包括分配和释放内存&#xff0c;这可能导致内存泄漏和指针错误。 适用于…

《TCP/IP网络编程》阅读笔记--epoll的使用

1--epoll的优点 select()的缺点&#xff1a; ① 调用 select() 函数后针对所有文件描述符的循环语句&#xff1b; ② 调用 select() 函数时需要向操作系统传递监视对象信息&#xff1b; epoll()的优点&#xff1a; ① 无需编写以监视状态变化为目的的针对所有文件描述符的循环语…

基于协同过滤算法的旅游推荐系统

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 项目介绍…

Linux服务器——进程/线程池

进程/线程池 动态创建子进程/线程的缺点&#xff1a; 比较耗时&#xff0c;这将导致较慢的客户响应&#xff1b;动态创建的子进程/线程通常只是用来为一个客户服务&#xff0c;这将导致系统上产生大量的细微进程/线程。进程/线程之间的切换将消耗大量 CPU 时间&#xff1b;动…

通过 while循环体对远程主机进行遍历性ssh登录并执行目标指令

实现方法&#xff1a; 一 对 ssh 命令使用选项“-n” 二 使用 for循环遍历替代 while循环遍历 三 对 while 循环体使用 exec描述符 问题的表现现象&#xff1a; while循环体只执行了目标文件中的第一行内容便推出循环了。 此现象也称作“while循环吃行现象”。 如以下实例…

springboot aop Aspectj 切面

常用&#xff1a; Aspect、Component、Pointcut、Before、AfterReturning SpringBoot的AOP&#xff08;aspect注解&#xff09;的简单使用 - 知乎 springboot项目中引入Aspectj并使用_springboot引入aspectj_山鬼谣me的博客-CSDN博客