当前位置: 首页 > news >正文

武平县天恒建设投资集团公司网站网站开发支付超时如何解决

武平县天恒建设投资集团公司网站,网站开发支付超时如何解决,东莞教育网官网,网站制作一般收费目录 并查集路径压缩 Java 实例代码 UnionFind3.java 文件代码: 并查集路径压缩 并查集里的 find 函数里可以进行路径压缩,是为了更快速的查找一个点的根节点。对于一个集合树来说,它的根节点下面可以依附着许多的节点,因此&am…

目录

 

并查集路径压缩

Java 实例代码

UnionFind3.java 文件代码:


 

并查集路径压缩

并查集里的 find 函数里可以进行路径压缩,是为了更快速的查找一个点的根节点。对于一个集合树来说,它的根节点下面可以依附着许多的节点,因此,我们可以尝试在 find 的过程中,从底向上,如果此时访问的节点不是根节点的话,那么我们可以把这个节点尽量的往上挪一挪,减少数的层数,这个过程就叫做路径压缩。

如下图中,find(4) 的过程就可以路径压缩,让数的层数更少。

 

b73a5a6a2514d6570c49f8a8cfba1199.png

节点 4 往上寻找根节点时,压缩第一步,树的层数就减少了一层:

 

dd4b7a55bdb3d579f0cd36f0f26542bf.png

节点 2 向上寻找,也不是根节点,那么把元素 2 指向原来父节点的父节点,操后后树的层数相应减少了一层,同时返回根节点 0。

 

4ba799185fbdd06993b533b577efb01f.png

find 过程代码修改为 :

// 查找过程, 查找元素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;

}

上述路径压缩并不是最优的方式,我们可以把最初的树压缩成下图所示,层数是最少的。

 

ada2100a73f1cd16278f193c38f15312.png

这个 find 过程代表表示为:

...
// 查找过程, 查找元素p所对应的集合编号
// O(h)复杂度, h为树的高度
private int find(int p) {
    assert (p >= 0 && p < count);

    //第二种路径压缩算法
    if (p != parent[p])
        parent[p] = find(parent[p]);
    return parent[p];
}
...

Java 实例代码

源码包下载:Download

UnionFind3.java 文件代码:

package runoob.union;

/**
 * 基于rank的优化
 */
public class UnionFind4 {

    private int[] rank;   // rank[i]表示以i为根的集合所表示的树的层数
    private int[] parent; // parent[i]表示第i个元素所指向的父节点
    private int count;    // 数据个数

    // 构造函数
    public UnionFind4(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 );
        // 不断去查询自己的父亲节点, 直到到达根节点
        // 根节点的特点: parent[p] == p
        while( p != parent[p] )
            p = parent[p];
        return p;

        //第二种路径压缩算法
        //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的值
        }
    }
}

 

http://www.yayakq.cn/news/282843/

相关文章:

  • 网站建设有哪种方式有名的公关公司
  • 免费的网站管理系统徐州建设安全监督网站
  • 网站空间域名是什么网络公司哪个效果好
  • wordpress主题 dux主题5.3seo行业岗位有哪些
  • 营销网站建设维护青岛贸易公司 网站制作
  • 丰台手机网站建设江西省建设工程安全质量监督管理局网站
  • 做好网站功能性建设工作网站扁平化结构和树形结构
  • 网站制作自己iis7架设网站教程
  • 控制面板网站html5网站建设思路
  • 网站建设 租赁上海外贸公司外滩27号
  • 电子政务网站建设方案网页配色设计手册
  • asp网站整站下载器长安区建设局网站
  • 贵州新农村建设专业网站网站开发重要性
  • 西宁网站建设最好的公司网站站长seo推广
  • 网站模板出售凡科做网站怎么样
  • 商城版免费网站卸载wordpress插件
  • 做简报的网站毕节公司做网站
  • 网站html模板绍兴市交通建设检测中心网站
  • 做微商如何网站推广掌门一对一辅导官网
  • 微信的公众平台网站开发什么网站访问量
  • 北京网站报价wordpress 如果存在则
  • 手表网站模版深圳十佳设计公司排名
  • 企业网站推广内容内部网站如何建设
  • 企业网站建设话术wordpress文章中显示打赏
  • 黑龙江网站建设费用上海做网站建设的公司排名
  • 厦门人才网唯一官方网站网站后台关键词链接怎样做
  • 房产中介如何找客源哈尔滨网站优化
  • 南京电信网站备案最好用的网站推广经验
  • 建网站作业北京互联网网站建设
  • 什么网站可以发布信息wordpress怎么连接数据库