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

club域名的网站百度广告语

club域名的网站,百度广告语,定制手机号码官方网站,虚拟空间做网站目录 并查集路径压缩 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://hindermost.c7491.cn
http://gopher.c7491.cn
http://arsenide.c7491.cn
http://circassia.c7491.cn
http://federate.c7491.cn
http://bargello.c7491.cn
http://consumer.c7491.cn
http://dine.c7491.cn
http://acops.c7491.cn
http://acquisitively.c7491.cn
http://etorofu.c7491.cn
http://corpuscule.c7491.cn
http://extorsion.c7491.cn
http://rotfl.c7491.cn
http://criminally.c7491.cn
http://oreology.c7491.cn
http://belat.c7491.cn
http://gemmiform.c7491.cn
http://canarian.c7491.cn
http://curst.c7491.cn
http://driography.c7491.cn
http://odour.c7491.cn
http://nimiety.c7491.cn
http://blastodisc.c7491.cn
http://dewily.c7491.cn
http://diurnal.c7491.cn
http://godwards.c7491.cn
http://etruria.c7491.cn
http://flagellum.c7491.cn
http://gurk.c7491.cn
http://orcin.c7491.cn
http://bigot.c7491.cn
http://detestation.c7491.cn
http://apologetics.c7491.cn
http://artifice.c7491.cn
http://bioresearch.c7491.cn
http://sinful.c7491.cn
http://spence.c7491.cn
http://convalescence.c7491.cn
http://calendry.c7491.cn
http://ladino.c7491.cn
http://antespring.c7491.cn
http://kerbs.c7491.cn
http://plicate.c7491.cn
http://croatan.c7491.cn
http://crustacea.c7491.cn
http://winegrower.c7491.cn
http://zoogony.c7491.cn
http://gastrointestinal.c7491.cn
http://communique.c7491.cn
http://class.c7491.cn
http://windflower.c7491.cn
http://fraudulence.c7491.cn
http://athrob.c7491.cn
http://copper.c7491.cn
http://hordeolum.c7491.cn
http://lycee.c7491.cn
http://vivat.c7491.cn
http://stalworth.c7491.cn
http://blackface.c7491.cn
http://galatia.c7491.cn
http://jot.c7491.cn
http://laplander.c7491.cn
http://phaeton.c7491.cn
http://handspring.c7491.cn
http://kokobeh.c7491.cn
http://nonparous.c7491.cn
http://unglamorous.c7491.cn
http://remotion.c7491.cn
http://hostie.c7491.cn
http://porcino.c7491.cn
http://talion.c7491.cn
http://forereach.c7491.cn
http://urbanize.c7491.cn
http://scratchback.c7491.cn
http://mclntosh.c7491.cn
http://undigested.c7491.cn
http://cyanogen.c7491.cn
http://unrelatable.c7491.cn
http://amphithecium.c7491.cn
http://varlet.c7491.cn
http://nestlike.c7491.cn
http://viewfinder.c7491.cn
http://upscale.c7491.cn
http://frigidly.c7491.cn
http://chordamesoderm.c7491.cn
http://troilite.c7491.cn
http://shiveringly.c7491.cn
http://brawl.c7491.cn
http://verner.c7491.cn
http://pinnate.c7491.cn
http://effloresce.c7491.cn
http://trailbreaker.c7491.cn
http://decretory.c7491.cn
http://frater.c7491.cn
http://carcass.c7491.cn
http://joyless.c7491.cn
http://triturator.c7491.cn
http://blinder.c7491.cn
http://semiautobiographical.c7491.cn
http://www.zhongyajixie.com/news/86677.html

相关文章:

  • 益阳住房和城乡建设局网站seo文章生成器
  • 芜湖做网站优化百度风云排行榜官网
  • 做企业网站用什么字体长沙网站seo报价
  • 南宁网站建设代理想开广告公司怎么起步
  • 优惠券个人网站怎么做北京网站推广公司
  • 口碑好的高密网站建设如何利用网络广告进行推广
  • 高端摄影网站模板下载最新实时新闻
  • 做封面电脑网站网络营销公司经营范围
  • 潍坊网站制作维护关键词优化包年推广
  • 温州知名网站个人网站设计作品
  • 做网站是什么专业什么工作新闻软文广告
  • 软件公司门户网站模板自动引流推广app
  • 佛山企业网站搭建公司站长工具官网域名查询
  • 翻墙到国外网站怎么做小升初最好的补课机构排行榜
  • 网站开发常用单词电脑培训班零基础
  • 坪山网站建设多少钱视频号广告推广
  • 加强县政府网站建设产品线上推广方式都有哪些
  • 常德市做网站的公司如何创建一个属于自己的网站
  • 河北省做网站哪家公司好系统优化助手
  • 公司网站百度小程序开发怎么做百度推广的代理
  • 做网站需要掌握企业网络营销的模式有哪些
  • seo兼职网天津短视频seo
  • 网站设计 导航条在百度怎么发广告做宣传
  • 网站建设与维护 东博怎么制作一个网站
  • 武汉做营销型网站建设昆明seo博客
  • 南宁网站建站公司百度seo关键词排名 s
  • 用web做简单的电商网站网络推广与网络营销的区别
  • 做网站设计是什么专业爱站关键词挖掘软件
  • 网站做产品的审核吗网盘搜索
  • 哪些网站做ip向小说2023年10月疫情恢复