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

            A Za, A Za, Fighting...

            堅信:勤能補拙

            PKU 2524 Ubiquitous Religions

            問題:
            http://acm.pku.edu.cn/JudgeOnline/problem?id=2524

            思路:
            簡單并查集,求連通分支的個數,一次AC

            代碼:
             1 #include<stdio.h>
             2 #include<stdlib.h>
             3 #include<string.h>
             4 #define MAX_NUM 50001
             5 int father[MAX_NUM];
             6 int rank[MAX_NUM];
             7 int total;
             8 
             9 void
            10 init(int n)
            11 {
            12     int i;
            13     for(i=1; i<=n; i++)
            14         father[i] = i;
            15     memset(rank, 0sizeof(rank));
            16     total = n;
            17 }
            18 
            19 int 
            20 find(int item)
            21 {
            22     if(father[item] != item)
            23         father[item] = find(father[item]);
            24     return father[item];
            25 }
            26 
            27 void
            28 uunion(int item1, int item2)
            29 {
            30     int a = find(item1);
            31     int b = find(item2);
            32     if(a == b)
            33         return;
            34     --total;
            35     if(rank[a] > rank[b])
            36         father[b] = a;
            37     else {
            38         father[a] = b;
            39         if(rank[a] == rank[b])
            40             ++rank[b];
            41     }
            42 }
            43 
            44 int
            45 main(int argc, char **argv)
            46 {
            47     int n, m, i, j, k, cnt=0;
            48     while(scanf("%d %d"&n, &m)!=EOF) {
            49         if(n==0 && m==0)
            50             break;
            51         init(n);
            52         for(k=0; k<m; k++) {
            53             scanf("%d %d"&i, &j);
            54             uunion(i, j);
            55         }
            56         printf("Case %d: %d\n"++cnt, total);
            57     }
            58 }

            posted on 2010-08-09 09:11 simplyzhao 閱讀(140) 評論(0)  編輯 收藏 引用 所屬分類: E_數據結構

            導航

            <2010年11月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            統計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国内精品九九久久久精品| 色偷偷88欧美精品久久久| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 亚洲精品乱码久久久久久蜜桃| 国内精品久久久久久中文字幕| 久久精品国产亚洲Aⅴ香蕉| 欧美日韩精品久久久久| 色欲综合久久躁天天躁蜜桃| 97久久超碰国产精品旧版| 人人狠狠综合久久亚洲| 三上悠亚久久精品| 久久精品国产只有精品66| 97精品伊人久久久大香线蕉| 国产精品久久一区二区三区| 亚洲国产精品无码久久久久久曰| 久久夜色精品国产欧美乱| 欧洲国产伦久久久久久久| 97r久久精品国产99国产精| 久久香综合精品久久伊人| 国产成人精品久久一区二区三区 | 久久久久久亚洲精品不卡| 久久精品夜夜夜夜夜久久| 久久综合九色综合欧美就去吻| 精品国产乱码久久久久久郑州公司 | 一本久久a久久精品vr综合| 久久精品一本到99热免费| 久久亚洲国产中v天仙www| 久久久久亚洲精品天堂久久久久久| 伊人久久五月天| 久久久久无码国产精品不卡| 久久精品99久久香蕉国产色戒 | 武侠古典久久婷婷狼人伊人| 久久99精品国产| 久久精品亚洲一区二区三区浴池 | 久久久久久久久久久久久久| 久久国产成人精品国产成人亚洲| 久久99精品国产99久久| 99久久婷婷免费国产综合精品| 九九精品99久久久香蕉| 久久综合给合久久狠狠狠97色 | 久久久久亚洲AV无码专区桃色|