亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java編程實(shí)現(xiàn)并查集的路徑壓縮代碼詳解

 更新時(shí)間:2017年11月28日 17:22:15   作者:HeatDeath  
這篇文章主要介紹了java編程實(shí)現(xiàn)并查集的路徑壓縮代碼詳解,具有一定借鑒價(jià)值,需要的朋友可以參考。

首先看兩張路徑壓縮的圖片:

并查集(Union-find Sets)是一種非常精巧而實(shí)用的數(shù)據(jù)結(jié)構(gòu),它主要用于處理一些不相交集合的合并問(wèn)題。一些常見的用途有求連通子圖、求最小生成樹的 Kruskal 算法和求最近公共祖先(Least Common Ancestors, LCA)等。

使用并查集時(shí),首先會(huì)存在一組不相交的動(dòng)態(tài)集合 S={S 1 ,S 2 ,⋯,S k } ,一般都會(huì)使用一個(gè)整數(shù)表示集合中的一個(gè)元素。
每個(gè)集合可能包含一個(gè)或多個(gè)元素,并選出集合中的某個(gè)元素作為代表。每個(gè)集合中具體包含了哪些元素是不關(guān)心的,具體選擇哪個(gè)元素作為代表一般也是不關(guān)心的。我們關(guān)心的是,對(duì)于給定的元素,可以很快的找到這個(gè)元素所在的集合(的代表),以及合并兩個(gè)元素所在的集合,而且這些操作的時(shí)間復(fù)雜度都是常數(shù)級(jí)的。

并查集的基本操作有三個(gè):

makeSet(s):建立一個(gè)新的并查集,其中包含 s 個(gè)單元素集合。
unionSet(x, y):把元素 x 和元素 y 所在的集合合并,要求 x 和 y 所在的集合不相交,如果相交則不合并。
find(x):找到元素 x 所在的集合的代表,該操作也可以用于判斷兩個(gè)元素是否位于同一個(gè)集合,只要將它們各自的代表比較一下就可以了。

package com.dataStructure.union_find;

// 我們的第五版Union-Find
public class UnionFind5 {

  // rank[i]表示以i為根的集合所表示的樹的層數(shù)
  // 在后續(xù)的代碼中, 我們并不會(huì)維護(hù)rank的語(yǔ)意, 也就是rank的值在路徑壓縮的過(guò)程中, 有可能不在是樹的層數(shù)值
  // 這也是我們的rank不叫height或者depth的原因, 他只是作為比較的一個(gè)標(biāo)準(zhǔn)
  private int[] rank;
  private int[] parent; // parent[i]表示第i個(gè)元素所指向的父節(jié)點(diǎn)
  private int count;  // 數(shù)據(jù)個(gè)數(shù)

  // 構(gòu)造函數(shù)
  public UnionFind5(int count){
    rank = new int[count];
    parent = new int[count];
    this.count = count;
    // 初始化, 每一個(gè)parent[i]指向自己, 表示每一個(gè)元素自己自成一個(gè)集合
    for( int i = 0 ; i < count ; i ++ ){
      parent[i] = i;
      rank[i] = 1;
    }
  }

  // 查找過(guò)程, 查找元素p所對(duì)應(yīng)的集合編號(hào)
  // O(h)復(fù)雜度, 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是否所屬一個(gè)集合
  // O(h)復(fù)雜度, h為樹的高度
  public boolean isConnected( int p , int q ){
    return find(p) == find(q);
  }

  // 合并元素p和元素q所屬的集合
  // O(h)復(fù)雜度, h為樹的高度
  public void unionElements(int p, int q){

    int pRoot = find(p);
    int qRoot = find(q);

    if( pRoot == qRoot )
      return;

    // 根據(jù)兩個(gè)元素所在樹的元素個(gè)數(shù)不同判斷合并方向
    // 將元素個(gè)數(shù)少的集合合并到元素個(gè)數(shù)多的集合上
    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;  // 此時(shí), 我維護(hù)rank的值
    }
  }
}

總結(jié)

以上就是本文關(guān)于java編程實(shí)現(xiàn)并查集的路徑壓縮代碼詳解的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!

相關(guān)文章

  • Java?HashSet的Removals()方法注意事項(xiàng)

    Java?HashSet的Removals()方法注意事項(xiàng)

    這篇文章主要介紹了Java?HashSet的Removals()方法注意事項(xiàng),文章圍繞制主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-06-06
  • java使用正則表達(dá)式過(guò)濾html標(biāo)簽

    java使用正則表達(dá)式過(guò)濾html標(biāo)簽

    本篇文章主要介紹了java正則表達(dá)式過(guò)濾html標(biāo)簽,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-11-11
  • Java中==與equals()及hashcode()三者之間的關(guān)系詳解

    Java中==與equals()及hashcode()三者之間的關(guān)系詳解

    最近也是在讀Hollis的《深入理解Java核心技術(shù)》里面一節(jié)講到了equals()和hashcode()的關(guān)系,對(duì)于這個(gè)高頻面試點(diǎn),咱們需要認(rèn)真理清一下幾者之間的關(guān)系
    2022-10-10
  • Java中怎樣使用JSON進(jìn)行文件解析

    Java中怎樣使用JSON進(jìn)行文件解析

    這篇文章主要介紹了Java中怎樣使用JSON進(jìn)行文件解析問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • JAVA?流程控制專項(xiàng)精講

    JAVA?流程控制專項(xiàng)精講

    不喜歡羅里吧嗦,講的很精簡(jiǎn)易懂。從基礎(chǔ)開始講,后續(xù)會(huì)講到JAVA高級(jí),中間會(huì)穿插面試題和項(xiàng)目實(shí)戰(zhàn),希望能給大家?guī)?lái)幫助
    2022-03-03
  • 詳解Java關(guān)于JDK中時(shí)間日期的API

    詳解Java關(guān)于JDK中時(shí)間日期的API

    這篇文章主要介紹了詳解Java關(guān)于JDK中時(shí)間日期的API,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-09-09
  • SpringBoot-JPA刪除不成功,只執(zhí)行了查詢語(yǔ)句問(wèn)題

    SpringBoot-JPA刪除不成功,只執(zhí)行了查詢語(yǔ)句問(wèn)題

    這篇文章主要介紹了SpringBoot-JPA刪除不成功,只執(zhí)行了查詢語(yǔ)句問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • 深入理解final變量的初始化

    深入理解final變量的初始化

    本篇文章是對(duì)final變量的初始化進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • SpringBoot之使用Feign實(shí)現(xiàn)微服務(wù)間的交互

    SpringBoot之使用Feign實(shí)現(xiàn)微服務(wù)間的交互

    這篇文章主要介紹了SpringBoot中使用Feign實(shí)現(xiàn)微服務(wù)間的交互,對(duì)微服務(wù)這方面感興趣的小伙伴可以參考閱讀本文
    2023-03-03
  • 深入理解SpringBoot?最大連接數(shù)及最大并發(fā)數(shù)

    深入理解SpringBoot?最大連接數(shù)及最大并發(fā)數(shù)

    SpringBoot能支持的最大并發(fā)量主要看其對(duì)Tomcat的設(shè)置,可以在配置文件中對(duì)其進(jìn)行更改,本文就來(lái)介紹一下SpringBoot?最大連接數(shù)及最大并發(fā)數(shù),感興趣的可以了解一下
    2023-08-08

最新評(píng)論