我的编程空间,编程开发者的网络收藏夹
学习永远不晚

java编程实现并查集的路径压缩代码详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

java编程实现并查集的路径压缩代码详解

首先看两张路径压缩的图片:

java编程实现并查集的路径压缩代码详解

java编程实现并查集的路径压缩代码详解

并查集(Union-find Sets)是一种非常精巧而实用的数据结构,它主要用于处理一些不相交集合的合并问题。一些常见的用途有求连通子图、求最小生成树的 Kruskal 算法和求最近公共祖先(Least Common Ancestors, LCA)等。

使用并查集时,首先会存在一组不相交的动态集合 S={S 1 ,S 2 ,⋯,S k } ,一般都会使用一个整数表示集合中的一个元素。
每个集合可能包含一个或多个元素,并选出集合中的某个元素作为代表。每个集合中具体包含了哪些元素是不关心的,具体选择哪个元素作为代表一般也是不关心的。我们关心的是,对于给定的元素,可以很快的找到这个元素所在的集合(的代表),以及合并两个元素所在的集合,而且这些操作的时间复杂度都是常数级的。

并查集的基本操作有三个:

makeSet(s):建立一个新的并查集,其中包含 s 个单元素集合。
unionSet(x, y):把元素 x 和元素 y 所在的集合合并,要求 x 和 y 所在的集合不相交,如果相交则不合并。
find(x):找到元素 x 所在的集合的代表,该操作也可以用于判断两个元素是否位于同一个集合,只要将它们各自的代表比较一下就可以了。

package com.dataStructure.union_find;// 我们的第五版Union-Findpublic class UnionFind5 {  // rank[i]表示以i为根的集合所表示的树的层数  // 在后续的代码中, 我们并不会维护rank的语意, 也就是rank的值在路径压缩的过程中, 有可能不在是树的层数值  // 这也是我们的rank不叫height或者depth的原因, 他只是作为比较的一个标准  private int[] rank;  private int[] parent; // parent[i]表示第i个元素所指向的父节点  private int count;  // 数据个数  // 构造函数  public UnionFind5(int count){    rank = new int[count];    parent = new int[count];    this.count = count;    // 初始化, 每一个parent[i]指向自己, 表示每一个元素自己自成一个集合    for( int i = 0 ; i < count ; i ++ ){      parent[i] = i;      rank[i] = 1;    }  }  // 查找过程, 查找元素p所对应的集合编号  // O(h)复杂度, h为树的高度  private int find(int p){    assert( p >= 0 && p < count );    // path compression 1    while( p != parent[p] ){      parent[p] = parent[parent[p]];      p = parent[p];    }    return p;    // path compression 2, 递归算法//      if( p != parent[p] )//        parent[p] = find( parent[p] );//      return parent[p];  }  // 查看元素p和元素q是否所属一个集合  // O(h)复杂度, h为树的高度  public boolean isConnected( int p , int q ){    return find(p) == find(q);  }  // 合并元素p和元素q所属的集合  // O(h)复杂度, h为树的高度  public void unionElements(int p, int q){    int pRoot = find(p);    int qRoot = find(q);    if( pRoot == qRoot )      return;    // 根据两个元素所在树的元素个数不同判断合并方向    // 将元素个数少的集合合并到元素个数多的集合上    if( rank[pRoot] < rank[qRoot] ){      parent[pRoot] = qRoot;    }    else if( rank[qRoot] < rank[pRoot]){      parent[qRoot] = pRoot;    }    else{ // rank[pRoot] == rank[qRoot]      parent[pRoot] = qRoot;      rank[qRoot] += 1;  // 此时, 我维护rank的值    }  }}

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

java编程实现并查集的路径压缩代码详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

java编程实现并查集的路径压缩代码详解

首先看两张路径压缩的图片:并查集(Union-find Sets)是一种非常精巧而实用的数据结构,它主要用于处理一些不相交集合的合并问题。一些常见的用途有求连通子图、求最小生成树的 Kruskal 算法和求最近公共祖先(Least Comm
2023-05-30

Java编程实现轨迹压缩之Douglas-Peucker算法详细代码

第一部分 问题描述1.1 具体任务  本次作业任务是轨迹压缩,给定一个GPS数据记录文件,每条记录包含经度和维度两个坐标字段,所有记录的经纬度坐标构成一条轨迹,要求采用合适的压缩算法,使得压缩后轨迹的距离误差小于30m。1.2 程序输入  
2023-05-30

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录