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

M.J的blog

algorithm,ACM-ICPC
隨筆 - 39, 文章 - 11, 評論 - 20, 引用 - 0
數(shù)據(jù)加載中……

TOJ 3499. Network(并查集)

今天簡單看了下并查集,關(guān)于優(yōu)化什么的還沒有看。做了兩個簡單的題,先熟悉一下~
并查集用來表示若干互不相交的集合,是一種樹狀的結(jié)構(gòu)。
并查集有三個操作:初始化,合并,查詢。
其中在合并的時候,由于可能集合是一個偏的很厲害的樹,如果不加分類直接合并的話,每次查詢會相當(dāng)浪費時間,所以
需要每次合并的時候?qū)⒁?guī)模小的集合并到規(guī)模大的集合,并且隨時更新集合內(nèi)元素的個數(shù)。
簡單的不優(yōu)化的Union函數(shù)如下:
1 Union(int root1,int root2)
2 {
3      int t1,t2;
4      t1=find(root1);
5      t2=find(root2);
6      if(t1!=t2)
7          t1.father=t2;
8      return ;
9 }
優(yōu)化后的Union函數(shù)如下:

 1 void Union(int root1,int root2)
 2 {
 3     int t1,t2;
 4     t1=find(root1);
 5     t2=find(root2);
 6     if(t1==t2) return ;                      //只有當(dāng)兩個根節(jié)點的祖先不同才合并
 7     if(t1!=t2){                              
 8         if(a[t1].v<a[t2].v){                 //將規(guī)模小的集合并到規(guī)模大的集合,同時集合元素個數(shù)增加
 9             a[t1].father=t2;
10             a[t2].v+=a[t1].v;
11         }
12         else{
13             a[t2].father=t1;
14                 a[t1].v+=a[t2].v;
15         }
16         
17     }
18 }

先看一下最簡單的并查集的模板:

 1 #include<stdio.h>
 2 #define MAX 10002
 3 int m,n;
 4 struct type
 5 {
 6     int father,v; //father 表示根節(jié)點,v表示集合內(nèi)元素個數(shù)
 7 }a[MAX];
 8 void initial(int n)
 9 {
10     int i;
11     for(i=0;i<n;i++){
12         a[i].father=i; //初始化將集合節(jié)點標(biāo)記為自己,元素個數(shù)為1
13         a[i].v=1;
14     }
15 }
16 int find(int n)
17 {    
18     if(a[n].father!=n)
19         return find(a[n].father); //此處也可以寫為 while(a[n].father!=n) n=a[n].father;
20     return n;
21 }
22 void Union(int root1,int root2)
23 {
24     int t1,t2;
25     t1=find(root1);
26     t2=find(root2);
27     if(t1==t2) return ; //只有當(dāng)兩個根節(jié)點的祖先不同才合并
28     if(t1!=t2){
29         if(a[t1].v<a[t2].v){ //將規(guī)模小的集合并到規(guī)模大的集合,同時集合元素個數(shù)增加
30             a[t1].father=t2;
31             a[t2].v+=a[t1].v;
32         }
33         else{
34             a[t2].father=t1;
35             a[t1].v+=a[t2].v;
36         }
37     }
38 }
39 int main()
40 {}
運用上邊的模板,就可以將TOJ 3499 AC掉了
題意大概是N個數(shù),從0到N-1,有M個關(guān)系,最后問P和Q之間是否是關(guān)系。
Code:
 1 #include<stdio.h>
 2 #define MAX 10002
 3 int m,n;
 4 struct type
 5 {
 6     int father,v;
 7 }a[MAX];
 8 void initial(int n)
 9 {
10     int i;
11     for(i=0;i<n;i++){
12         a[i].father=i;
13         a[i].v=1;
14     }
15 }
16 int find(int n)
17 {
18     if(a[n].father!=n)
19         return find(a[n].father);
20     return n;
21 }
22 void Union(int root1,int root2)
23 {
24     int t1,t2;
25     t1=find(root1);
26     t2=find(root2);
27     if(t1==t2) return ;
28     if(t1!=t2){
29         if(a[t1].v<a[t2].v){
30             a[t1].father=t2;
31             a[t2].v+=a[t1].v;
32         }
33         else{
34             a[t2].father=t1;
35             a[t1].v+=a[t2].v;
36         }
37     }
38 }
39 int main()
40 {
41     int cas,i,j,k,p,q,N,M;
42     while(scanf("%d%d%d",&N,&M,&k)!=EOF){
43         initial(N);
44         for(i=0;i<M;i++){
45             scanf("%d%d",&p,&q);
46             Union(p,q);
47         }
48         for(i=1;i<=k;i++){
49             scanf("%d%d",&p,&q);
50             if(find(p)==find(q))
51                 printf("YES\n");
52         else printf("NO\n");
53     }
54     }
55 }

posted on 2010-04-24 14:55 M.J 閱讀(196) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美中文在线观看| 国产精品超碰97尤物18| 美女视频网站黄色亚洲| 欧美影院在线| 久久精品二区| 免费不卡中文字幕视频| 欧美大片一区| 一区二区不卡在线视频 午夜欧美不卡在 | 久久国产精品久久国产精品| 久久国产精品久久w女人spa| 麻豆国产精品777777在线 | 亚洲一区亚洲| 久久高清福利视频| 国产精品久久午夜夜伦鲁鲁| 亚洲精选视频在线| 在线精品一区二区| 日韩视频在线你懂得| 在线亚洲伦理| 亚洲欧美一区二区在线观看| 久久激情婷婷| 亚洲激情亚洲| 国产精品久久久久久久久久ktv | 亚洲激情另类| 亚洲欧美日韩国产中文| 免费成人激情视频| 9久草视频在线视频精品| 欧美伊人久久久久久久久影院| 久久亚裔精品欧美| 亚洲欧美日韩区| 久久视频国产精品免费视频在线| 欧美黄色网络| 国产专区综合网| 在线视频你懂得一区| 久久aⅴ乱码一区二区三区| 亚洲国产精品视频| 久久av二区| 国产精品免费在线| 99pao成人国产永久免费视频| 久久久成人精品| 99re视频这里只有精品| 麻豆精品在线视频| 黑人极品videos精品欧美裸| 国产在线精品二区| 亚洲一区二区三区视频播放| 欧美国产精品专区| 久久久美女艺术照精彩视频福利播放 | 亚洲国产精品va在看黑人| 亚洲视频欧美在线| 欧美日韩国产成人在线91| 在线观看日产精品| 久久精品人人| 亚洲欧美一区二区原创| 国产精品久久二区| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲国产精品一区二区三区| 久久嫩草精品久久久久| 韩国一区二区三区在线观看| 久久精品成人一区二区三区| 亚洲欧美日韩系列| 国产日韩欧美三级| 久久精品欧美日韩| 久久爱91午夜羞羞| 国产日韩专区在线| 久久天天躁狠狠躁夜夜av| 欧美亚洲一区二区在线观看| 国产美女精品| 国产精品免费一区二区三区在线观看 | 欧美日韩国产色综合一二三四 | 一区二区三区精品国产| 亚洲人体大胆视频| 欧美日韩精品系列| 午夜欧美大尺度福利影院在线看| 一本色道久久综合亚洲精品高清| 欧美私人网站| 国产性做久久久久久| 久久福利资源站| 久久久在线视频| 日韩天堂在线观看| 亚洲综合国产精品| 亚洲福利电影| 日韩一区二区高清| 国产亚洲午夜高清国产拍精品| 久久噜噜噜精品国产亚洲综合| 久久精品卡一| 亚洲美女淫视频| 亚洲新中文字幕| 久久综合色综合88| 亚洲精品美女在线观看播放| 99在线热播精品免费| 国产亚洲精品bv在线观看| 美女任你摸久久| 欧美日韩午夜激情| 久久精品一区二区三区中文字幕| 久久综合九色| 亚洲欧美日韩综合国产aⅴ | 欧美日韩一区二区三区四区在线观看 | 久久精品国产免费看久久精品| 久久久久免费视频| aa亚洲婷婷| 欧美专区在线观看一区| 亚洲日韩视频| 欧美一区二区三区视频免费| 亚洲美女一区| 欧美怡红院视频| 中文在线资源观看视频网站免费不卡| 亚洲欧美国产77777| 亚洲三级电影全部在线观看高清| 亚洲女人天堂av| 99精品国产高清一区二区| 欧美一区91| 亚洲欧美日韩另类| 欧美成人四级电影| 久久久久久穴| 国产精品家教| 亚洲精品国偷自产在线99热| 国内精品久久久久久 | 亚洲精品自在久久| 激情六月综合| 亚洲欧美日韩成人高清在线一区| 亚洲激情在线播放| 欧美一区午夜视频在线观看| 亚洲一区在线播放| 欧美精品三级| 免费试看一区| 国产美女精品人人做人人爽| 一区二区高清| 99re热这里只有精品视频 | 欧美视频观看一区| 欧美激情精品久久久久久久变态| 国产精品九九| 亚洲美女av黄| 亚洲国产精品一区二区www在线 | 鲁鲁狠狠狠7777一区二区| 欧美一区二区三区日韩| 欧美日本国产精品| 亚洲国产一区二区三区在线播 | 国产农村妇女精品一二区| 日韩视频免费在线观看| 最新日韩中文字幕| 欧美成人tv| 男女精品网站| 亚洲福利在线视频| 美女在线一区二区| 久久综合电影一区| 国内成+人亚洲| 久久gogo国模啪啪人体图| 久久天天躁狠狠躁夜夜av| 国产欧美一区二区三区久久| 亚洲中午字幕| 久久久亚洲影院你懂的| 国产精品手机视频| 亚洲永久精品国产| 一区二区日韩欧美| 欧美一级理论性理论a| 国产精品人成在线观看免费| 亚洲精品一区二区三区婷婷月| 亚洲精品久久久久久下一站| 欧美日本不卡| 亚洲天堂免费观看| 欧美一级欧美一级在线播放| 国产伦精品一区二区三区| 亚洲欧美成人一区二区在线电影 | 美女精品视频一区| 亚洲第一区中文99精品| 最近中文字幕日韩精品| 欧美激情第六页| 亚洲香蕉视频| 久久婷婷丁香| 亚洲人成人一区二区三区| 欧美日韩国产色综合一二三四| 夜夜夜久久久| 免费观看亚洲视频大全| 亚洲美女精品一区| 国产精品网站在线观看| 免费在线成人av| 亚洲精品一区二区三区av| 欧美午夜不卡在线观看免费| 久久黄色级2电影| 亚洲韩国青草视频| 欧美一区二区日韩| 亚洲电影免费| 国产精品国码视频| 欧美成人免费在线视频| 亚洲一级黄色| 欧美二区乱c少妇| 午夜精品久久久久影视| 亚洲精品视频免费| 国内成人精品2018免费看| 欧美日韩精品免费观看视频| 日韩午夜在线电影| 欧美在线|欧美| 亚洲香蕉在线观看| 亚洲国产精品一区二区尤物区| 欧美国产亚洲精品久久久8v| 亚洲视频自拍偷拍| 亚洲美女中文字幕| 欧美aⅴ99久久黑人专区| 亚洲欧美国产视频| 日韩天天综合| 亚洲国产精品视频|