青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0
<2010年8月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

常用鏈接

留言簿(24)

隨筆分類(332)

隨筆檔案(182)

FRIENDS

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

評論排行榜

自己的 并查集 模板

Posted on 2010-08-10 11:36 MiYu 閱讀(542) 評論(0)  編輯 收藏 引用 所屬分類: ACM ( 并查集 )ACM ( MST 最小生成樹 )
MiYu原創, 轉帖請注明 : 轉載自 ______________白白の屋

剛剛學習完并查集的基礎知識.. 自己寫了3個模板類 . 發上和大家分享下:

MiYu原創, 轉帖請注明 : 轉載自 ______________白白の屋

#include 
<iostream>
using namespace std;
typedef 
class arrUFS{
       
public:
              arrUFS(
int n = 0):N(n){ set = new int[n]; for ( int i = 0; i != N; ++ i) set[i] = i; };
              
~arrUFS(){ delete [] set; };
              
int find ( int x ){ return set[x]; }
              
void Merge1( int a,int b){   int i = min(set[a],set[b]);
                                           
int j = max(set[a],set[b]);
                                           
for ( int k=1; k<=N; k++) {
                                                 
if (set[k] == j)
                                                 
set[k] = i;
                                           }
                                       }
       
private:
              
int *set;
              
int N;         
}arrUFS; 
// 數組形式

//樹形并查集, 路徑壓縮 
typedef struct {
     
int parent;
     
int cnt;   
}Tset;  

typedef 
class treeUFS{
       
public:
              treeUFS(
int n = 0):N(n+2) { set = new Tset[N]; 
                                          
for ( int i = 0; i != N; ++ i) 
                                          
set[i].parent = i,set[i].cnt = 1
                                        }
              
~treeUFS(){ delete [] set; };
              
int find ( int x ){ int r = x; while ( set[r].parent != r ) //循環結束,則找到根節點
                                                    r = set[r],parent;       
                                             
int i = x;
                                             
while ( i != r) //本循環修改查找路徑中所有節點
                                             {   
                                                 
int j = set[i].parent;
                                                 
set[i].parent = r;
                                                 i 
= j;
                                             } 
                                   
return r;
                                }
              
void Merge1( int x,int y ){  x = find ( x );  y = find ( y );  
                                           
if ( x == y ) return;
                                           
if ( set[x].cnt > set[y].cnt ){
                                                
set[y].parent = x;
                                                
set[x].cnt += set[y].cnt;
                                           }
                                           
else{
                                                   
set[x].parent = y;
                                                   
set[y].cnt += set[x].cnt;        
                                               }
                                        }
       
private:
              
int *set;
              
int N;         
}treeUFS; 
// 樹形式  路徑壓縮 

//屬性并查集, 帶樹深 
typedef struct {
     
int parent;
     
int height;   
}Tset;  

typedef 
class treeUFS{
       
public:
              treeUFS(
int n = 0):N(n+2) { set = new Tset[N];
                                          visited 
= new bool[N]; 
                                          
for ( int i = 0; i != N; ++ i) 
                                          
set[i].parent = i,set[i].height = 1,visited[i] = false
                                        }
              
~treeUFS(){ delete [] set; };
              
int find ( int x ){  int r = x;  while ( r != set[r].parent ) r = ser[r].parent;
                                   
return r;
                                }
              
void Merge1( int x,int y ){  x = find ( x );  y = find ( y );  
                                           
if ( x == y ) return;
                                           
if ( set[x].height == set[y].height ){
                                                
set[y].parent = x;
                                                
set[x].height ++;
                                           }
                                           
else if ( set[x].height < set[y].height ) {
                                                     
set[x].parent = y;       
                                                   }
                                           
else{
                                                     
set[y].parent = x;
                                               }
                                        }
       
private:
              
int *set;
              
bool *visited;
              
int N;         
}treeUFS; 
// 樹形式 帶樹深 

int main ()
{
    
return 0
}
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产专区欧美精品| 悠悠资源网久久精品| 亚洲视频第一页| 99re66热这里只有精品4| 欧美精品电影| 亚洲综合国产| 亚洲欧美在线一区二区| 国产亚洲精品一区二555| 久久亚洲不卡| 免费久久久一本精品久久区| 亚洲美女黄网| 亚洲天堂网在线观看| 国产主播精品| 亚洲国产高清在线观看视频| 欧美激情2020午夜免费观看| 亚洲免费视频一区二区| 欧美一级免费视频| 亚洲激情成人网| 一本高清dvd不卡在线观看| 国产亚洲精品资源在线26u| 欧美成人首页| 国产精品久久国产三级国电话系列| 亚洲欧美日韩一区| 久久久一区二区| 亚洲天天影视| 久久久久成人精品| 一本色道久久综合狠狠躁篇的优点 | 免费一区二区三区| 欧美国产日韩一二三区| 久久国产精品久久久久久电车| 玖玖玖国产精品| 亚洲一区二区日本| 久久精品最新地址| 在线一区二区三区四区五区| 欧美尤物巨大精品爽| 中文网丁香综合网| 欧美在线视频一区二区三区| 一区二区欧美日韩| 久久精品一区二区三区中文字幕| 中文亚洲欧美| 欧美成人高清| 久久久久久**毛片大全| 欧美日韩国产一区二区三区| 能在线观看的日韩av| 国产精品无码专区在线观看 | 午夜精品久久久久久久久久久久久 | 99在线观看免费视频精品观看| 在线观看视频欧美| 午夜在线视频一区二区区别| 亚洲一区二区三区免费观看| 欧美电影打屁股sp| 免费亚洲电影在线| 国产一区二区精品丝袜| 亚洲在线免费视频| 亚洲性夜色噜噜噜7777| 欧美激情免费观看| 欧美激情va永久在线播放| 一区二区三区自拍| 久久爱www久久做| 久久精品成人一区二区三区蜜臀| 欧美三级午夜理伦三级中文幕 | 久久资源在线| 国产亚洲免费的视频看| 亚洲女性裸体视频| 欧美中文字幕精品| 国产伦理精品不卡| 午夜国产不卡在线观看视频| 午夜久久久久| 国产欧美成人| 欧美一区二区三区日韩| 欧美一区二区免费观在线| 国产精品一区二区久久久| 亚洲制服少妇| 久久久精品动漫| 韩日成人在线| 久久精品在线观看| 奶水喷射视频一区| 亚洲黄色大片| 欧美日韩免费观看一区| 亚洲精品中文字| 亚洲性视频网址| 国产精品嫩草99a| 午夜久久资源| 免费成人激情视频| 亚洲精品日韩激情在线电影 | 久久久久99| 亚洲第一网站| 亚洲午夜电影在线观看| 国产精品日韩欧美大师| 久久av免费一区| 亚洲国产成人91精品| 亚洲一区二区三区视频播放| 国产偷自视频区视频一区二区| 久久青青草综合| 日韩一区二区免费高清| 久久av一区二区三区漫画| 亚洲第一福利在线观看| 欧美成人国产va精品日本一级| 日韩一区二区免费高清| 久久精品国产在热久久| 99av国产精品欲麻豆| 国产精品激情电影| 久久久久久久久久久成人| a4yy欧美一区二区三区| 久久久久亚洲综合| 国产精品99久久久久久有的能看 | 欧美激情视频网站| 亚洲女性喷水在线观看一区| 亚洲国产老妈| 久久网站热最新地址| 一本色道88久久加勒比精品| 黑人巨大精品欧美一区二区小视频| 欧美激情综合网| 久久精品盗摄| 亚洲午夜黄色| 最新国产拍偷乱拍精品| 久久久噜噜噜久久狠狠50岁| 亚洲永久视频| 在线亚洲一区二区| 亚洲精品四区| 亚洲第一在线| 国产最新精品精品你懂的| 国产精品久久7| 欧美另类videos死尸| 久久一二三区| 久久久精彩视频| 午夜亚洲影视| 亚洲一区二区三区免费观看| 亚洲毛片在线观看| 欧美激情一区二区三区| 欧美+亚洲+精品+三区| 久久久国产成人精品| 午夜精品视频| 午夜精品影院在线观看| 亚洲性线免费观看视频成熟| 一区二区欧美视频| 日韩视频专区| 亚洲精品国产无天堂网2021| 亚洲大片精品永久免费| 国产亚洲精品久久久| 国产欧美日韩在线视频| 国产欧美日韩另类一区| 国产精品久久一卡二卡| 国产精品成人一区二区网站软件| 欧美日韩一区自拍| 欧美日韩国产首页在线观看| 欧美日韩国产色站一区二区三区| 欧美精品一卡| 欧美日韩国产色视频| 欧美色图一区二区三区| 国产精品美腿一区在线看| 国产精品一区二区久久| 国产丝袜一区二区| 国产一区二区无遮挡| 在线日韩电影| 亚洲美女电影在线| 亚洲午夜在线视频| 久久www成人_看片免费不卡 | 亚洲伦理精品| 一本久久综合亚洲鲁鲁| 亚洲视频视频在线| 久久er精品视频| 久久综合狠狠综合久久激情| 欧美国产91| 亚洲精品无人区| 午夜精品久久久久久久久久久久| 久久国产精品网站| 欧美激情欧美狂野欧美精品| 欧美视频中文在线看| 国产毛片一区二区| 在线免费观看日本欧美| 夜夜爽www精品| 欧美一区二区女人| 欧美激情久久久久| 正在播放日韩| 久久综合狠狠综合久久综合88| 欧美日韩精品欧美日韩精品| 国产精品一区二区在线观看不卡| 尤妮丝一区二区裸体视频| av不卡在线观看| 久久精品国产久精国产爱| 欧美大胆人体视频| 亚洲性视频h| 欧美+日本+国产+在线a∨观看| 国产精品v欧美精品v日韩| 激情一区二区三区| 亚洲影院在线观看| 欧美**人妖| 午夜久久tv| 欧美性大战久久久久| 亚洲第一在线综合在线| 亚洲欧美日韩在线| 亚洲激情网址| 久久精品免费播放| 国产精品久久久久久久久果冻传媒 | 亚洲视频在线二区| 免费永久网站黄欧美| 亚洲欧美日韩精品久久亚洲区| 欧美大片一区二区| 黑人极品videos精品欧美裸|