• <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>

            Better man

            改變性格 改變命運(yùn)!

             

            zoj 2833

             1 //并查集
             2 //并查集可以判斷圖的連通性
             3 //并查集其實(shí)還有一個(gè)優(yōu)化:就是路徑壓縮:即找到u所在樹(shù)的跟v以后,把從u到v的路徑上的所有點(diǎn)的父親都設(shè)置為v,這樣可以有效的減少查找的時(shí)間
             4 //zoj2833
             5 #include <iostream>
             6 using namespace std;
             7 int n,m;
             8 int father[100000+1];
             9 int f[100000+1];//朋友的個(gè)數(shù)
            10 int rank[100000+1];
            11 void make_set(int s)
            12 {
            13       for(int i=1;i<=s;++i)
            14       {
            15             f[i]=1;
            16             father[i]=i;
            17             rank[i]=0;
            18       }
            19 }
            20 int find_set(int x)
            21 {
            22       if(x!=father[x])
            23             father[x]=find_set(father[x]);
            24       return father[x];
            25 }
            26 void union_set(int x,int y)
            27 {
            28       int a=find_set(x);
            29       int b=find_set(y);
            30       if(rank[a]>rank[b])
            31       {
            32             father[b]=a;
            33             f[a]+=f[b];
            34       }
            35       else
            36       {
            37             father[a]=b;
            38             f[b]+=f[a];
            39       }
            40       if(rank[a]==rank[b])rank[b]++;
            41 
            42 
            43 int main()
            44 {      
            45       int a,b;
            46       char tmp;
            47       int cas=0;
            48       while(scanf("%d%d",&n,&m)!=EOF)
            49       {
            50             if(cas)printf("\n");
            51             printf("Case %d:\n",++cas);
            52             make_set(n);
            53             getchar();
            54             for(int i=1;i<=m;++i)
            55             {
            56                   tmp=getchar();
            57                   if(tmp=='M')
            58                   {
            59                         scanf("%d%d",&a,&b);
            60                         if(find_set(a)!=find_set(b))
            61                               union_set(a,b);
            62                   }
            63                   if(tmp=='Q')
            64                   {
            65                         scanf("%d",&a);
            66                         int sum=f[find_set(a)];
            67                         printf("%d\n",sum);
            68                   }
            69                   getchar();
            70             }
            71       }
            72       return 0;
            73 }
            74 

            posted on 2009-02-04 13:55 SHFACM 閱讀(684) 評(píng)論(0)  編輯 收藏 引用


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


            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(2)

            隨筆檔案

            文章分類(lèi)

            文章檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久久精品免费国产四虎| 国产成人精品三上悠亚久久| 一本色道久久88—综合亚洲精品| 国产精品久久久久一区二区三区| 久久99国产综合精品女同| 日产精品久久久久久久性色| 18岁日韩内射颜射午夜久久成人| 久久91精品国产91久| 7777精品伊人久久久大香线蕉| 天堂无码久久综合东京热| 理论片午午伦夜理片久久| 天天综合久久一二三区| 久久久久99这里有精品10 | 久久福利资源国产精品999| 亚洲?V乱码久久精品蜜桃| 久久精品人妻中文系列| 久久A级毛片免费观看| 国内精品久久久久久久亚洲| 久久夜色撩人精品国产| 久久夜色精品国产噜噜亚洲a| 久久久女人与动物群交毛片| 亚洲乱亚洲乱淫久久| 四虎国产精品成人免费久久| www.久久99| 免费无码国产欧美久久18| 国内精品久久久久影院日本 | 伊人久久大香线蕉综合网站| 亚洲精品美女久久777777| 久久免费线看线看| 人妻无码精品久久亚瑟影视| 狠狠色丁香久久综合五月| 久久精品国产一区二区三区| 婷婷伊人久久大香线蕉AV | 97热久久免费频精品99| 久久99精品久久久久久野外| 久久久亚洲欧洲日产国码二区| 久久久精品国产Sm最大网站| 韩国免费A级毛片久久| 国产精品久久久久久五月尺| 国产99久久久久久免费看| 国内精品久久久久伊人av|