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

O(1) 的小樂

Job Hunting

公告

記錄我的生活和工作。。。
<2010年9月>
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789

統(tǒng)計

  • 隨筆 - 182
  • 文章 - 1
  • 評論 - 41
  • 引用 - 0

留言簿(10)

隨筆分類(70)

隨筆檔案(182)

文章檔案(1)

如影隨形

搜索

  •  

最新隨筆

最新評論

閱讀排行榜

評論排行榜

POJ 2524 并查集

之前這個問題用深度優(yōu)先搜索做的。。耗時很長,很顯然這是一個并查集的題目:

#include<stdio.h>
#include<vector>
#include<algorithm>
using namespace std;
vector <int> a[50001];
int n,m,col;
bool v[50001];
void dfs(int k)
{
    int i,j;
    v[k]=1;
    for(i=0;i<a[k].size();i++)
        if(v[a[k][i]]==0)dfs(a[k][i]);
}    
int main()
{
    int i,j,p,q,cn=0;
    while(scanf("%d %d",&n,&m),n||m)
    {
        for(i=1;i<=n;i++)a[i].clear(),v[i]=0;
        for(i=0;i<m;i++)scanf("%d %d",&p,&q),a[p].push_back(q),a[q].push_back(p);
        col=0;
        for(i=1;i<=n;i++)if(v[i]==0)dfs(i),col++;
        printf("Case %d: %d\n",++cn,col);    
    }    
    return 0;
}    

 

 

并查集版本:

#include <iostream>
using namespace std;

#define MAXN 500001
struct
{
     int parent;
     int rank;
}UFS[MAXN];          //UnionFindSet   UFS

//其中Parent為正數(shù)時表示該節(jié)點的父節(jié)點下標,為負數(shù)時表示該節(jié)點為一個根節(jié)點,其絕對值為該集合包含的節(jié)點總數(shù)。
//rank表示權值,在不同問題中有不同的含義。

void MakeSet(int N)     /* 初始化 */
{
     int i;

     for(i=0;i<=N;i++)      //額外增加一位,從0開始可以從1開始也可以
     {
         UFS[i].parent=-1;  /* 開始每個節(jié)點單獨構成一個集合 */
         UFS[i].rank=0;     /* 權值視具體情況付初值 */
     }
}

int Root(int x)     /* 查找包含接點x的集合的根節(jié)點 */

{
     int i=x,temp;
     while(UFS[i].parent>0)
         i=UFS[i].parent;

     while(i!=x)     /* 壓縮路徑以提高以后檢索效率 */
     {
         temp=UFS[x].parent;            
         UFS[x].parent=i;               //直接將x的祖先命為根節(jié)點
         x=temp;                                 //繼續(xù)處理x的原祖先
     }
     return i;
}

void Union1(int a,int b)     /* 合并a和b所在的集合 */
{
     int fa,fb;
     fa=Root(a);
     fb=Root(b);
     if(fa==fb) return;

     if(UFS[fa].parent<UFS[fb].parent)     /* 始終將較小樹作為較大樹的子樹 */
     {
         UFS[fa].parent+=UFS[fb].parent;
         UFS[fb].parent=fa;
     }
     else
     {
         UFS[fb].parent+=UFS[fa].parent;
         UFS[fa].parent=fb;
     }
}
void Union2(int a, int b)     //將rank較大的作為父節(jié)點
{
    int x = Root(a), y = Root(b);
    if( x == y ) return ;
    if( UFS[x].rank > UFS[y].rank ) UFS[y].parent = x;
    else{
        UFS[x].parent = y;
        if( UFS[x].rank == UFS[y].rank ) UFS[y].rank++;
    }
}

int main()
{
    int N, M, a, b;
    int nCases = 1;
    while(scanf("%d %d", &N, &M) && (M||N))
    {
        MakeSet(N);
        for(int i=1; i<=M; ++i)
        {
            scanf("%d %d", &a, &b);
            a = Root(a);
            b = Root(b);
            //如果a,b不在同一個集合,則合并
            if(a != b)
            {
                N--;
                Union2(a, b);
            }
        }
        printf("Case %d: %d\n", nCases++, N);
    }
    return 0;
}

今天明天總結一下并查集的相關知識吧!

posted on 2010-09-27 22:41 Sosi 閱讀(531) 評論(0)  編輯 收藏 引用

統(tǒng)計系統(tǒng)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品国产亚洲一区二区| 亚洲人成亚洲人成在线观看| 亚洲视频一区二区| 欧美日韩中字| 亚洲伊人观看| 欧美一级精品大片| 国内久久婷婷综合| 欧美成人激情视频| 欧美日韩国产91| 亚洲资源av| 久久国产黑丝| 亚洲精品中文字幕在线观看| 亚洲精品综合在线| 国产精品一区免费观看| 久久影音先锋| 欧美午夜欧美| 久久色中文字幕| 欧美激情国产日韩| 欧美在线观看视频一区二区| 久久久久久综合网天天| 夜夜嗨av一区二区三区中文字幕| 亚洲网站在线播放| 一区二区在线免费观看| 亚洲免费av片| 一区在线观看| 一区二区三区日韩欧美精品| 影音先锋一区| 中文欧美日韩| 亚洲日本中文字幕区| 亚洲一区成人| 亚洲精品国产精品乱码不99按摩| 亚洲综合色婷婷| 99一区二区| 久久久久免费视频| 先锋影音网一区二区| 欧美成人日韩| 看欧美日韩国产| 国产精品一区二区三区成人| 亚洲日本欧美日韩高观看| 黄色工厂这里只有精品| 中国女人久久久| 日韩一级精品| 久色成人在线| 久久综合狠狠综合久久综青草| 国产精品国产三级国产普通话蜜臀 | 一区二区三区欧美视频| 亚洲国产精品一区二区久| 午夜在线成人av| 亚洲香蕉网站| 欧美日韩国产欧美日美国产精品| 另类春色校园亚洲| 国产在线日韩| 久久精品在线播放| 久久精品国产精品 | 欧美天天影院| 亚洲精品久久嫩草网站秘色| 亚洲激情欧美| 欧美精品激情blacked18| 亚洲免费福利视频| 亚洲激情欧美激情| 欧美成人69av| 欧美国产精品久久| 欧美一区二区日韩| 国产精品豆花视频| 亚洲欧美日韩精品| 欧美午夜精彩| 在线亚洲自拍| 午夜精品成人在线| 国产精品手机在线| 亚洲在线观看| 欧美一级欧美一级在线播放| 国产女精品视频网站免费| 亚洲欧美日韩国产| 久久国产精彩视频| 狠色狠色综合久久| 欧美a级大片| 亚洲精品免费电影| 亚洲女同性videos| 国产婷婷精品| 免费人成网站在线观看欧美高清| 亚洲国产女人aaa毛片在线| 日韩视频免费| 国产精品一二一区| 久久嫩草精品久久久精品一| 亚洲大片一区二区三区| 一区二区高清视频| 国产美女搞久久| 久久乐国产精品| 91久久午夜| 久久精品123| 亚洲激情另类| 国产精品亚洲精品| 另类成人小视频在线| 亚洲精品一区二区三| 欧美在线你懂的| 亚洲激情在线观看视频免费| 欧美视频一区二区三区在线观看| 亚洲欧美卡通另类91av| 欧美国产日韩一区二区| 亚洲欧美日韩天堂| 亚洲国产1区| 国产精品普通话对白| 免费日韩av| 午夜一区二区三区不卡视频| 欧美国产日韩一区二区三区| 午夜伦理片一区| 91久久久国产精品| 国产在线欧美日韩| 国产精品v片在线观看不卡| 噜噜噜91成人网| 亚洲欧美国产77777| 亚洲国产精品成人久久综合一区| 欧美在线免费看| 亚洲少妇诱惑| 亚洲欧洲日本一区二区三区| 国产精品视频免费| 欧美日韩一级片在线观看| 久久精品在线观看| 欧美一区免费| 亚洲男人的天堂在线| 亚洲国产高清在线| 蜜臀av在线播放一区二区三区| 午夜精品久久久久久99热软件| 日韩网站免费观看| 最新高清无码专区| 在线观看欧美日韩| 国产一区二区三区成人欧美日韩在线观看| 欧美日韩国产免费观看| 欧美高清视频一区| 嫩草国产精品入口| 欧美亚洲第一页| 亚洲欧美日韩精品久久久| 亚洲欧洲一区二区三区久久| 国产亚洲福利| 国产欧美一区二区三区另类精品| 欧美人与禽性xxxxx杂性| 欧美jizz19性欧美| 欧美岛国激情| 欧美精品麻豆| 欧美另类亚洲| 欧美日韩影院| 欧美日韩在线高清| 欧美少妇一区二区| 国产精品xxxxx| 国产精品国产三级国产专播精品人| 欧美精品少妇一区二区三区| 欧美精品系列| 欧美日韩综合精品| 国产精品欧美久久久久无广告| 欧美性生交xxxxx久久久| 欧美午夜性色大片在线观看| 国产精品久久久久影院色老大 | 亚洲日本视频| 9人人澡人人爽人人精品| 中文国产亚洲喷潮| 午夜视频一区二区| 久久婷婷久久| 欧美老女人xx| 国产精品丝袜白浆摸在线| 国产欧美日韩精品一区| 国外成人免费视频| 亚洲人午夜精品| 亚洲小说春色综合另类电影| 欧美一区二区三区男人的天堂| 久久久久欧美| 亚洲精品韩国| 亚洲欧洲99久久| 你懂的视频欧美| 国产精品亚洲综合一区在线观看| 国产综合视频| 在线亚洲欧美视频| 久久成人人人人精品欧| 亚洲大胆人体视频| 在线视频精品一区| 久久久久久久一区二区| 欧美精品一区三区在线观看| 国产精品毛片在线看| 在线观看欧美视频| 中文亚洲免费| 久久在线视频在线| 在线视频你懂得一区| 久久久99免费视频| 国产精品国产三级国产aⅴ浪潮| 黄色成人在线网址| 亚洲欧美日韩综合一区| 欧美大片18| 亚洲摸下面视频| 欧美巨乳波霸| 伊伊综合在线| 亚洲欧美综合国产精品一区| 欧美激情精品久久久久久黑人 | 久久国产一区| 国产精品成人播放| 91久久在线视频| 久久在线观看视频| 亚洲午夜成aⅴ人片| 欧美大片免费观看在线观看网站推荐| 国产精品一区二区三区乱码| 一本一本久久| 欧美激情一区二区三区在线视频观看 |