• <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>
            posts - 24,  comments - 0,  trackbacks - 0
            今天做了幾道最小生成樹的初級題,不過只學習了Kruskal,感覺挺好用的
            hdu上的練手題
            1301
            1233
            1863
            1162
            1879
            1875
            1102
            摸板:http://acm.hdu.edu.cn/showproblem.php?pid=1233
             1 #include<cstdio>
             2 #include<algorithm>
             3 #include<cstring>
             4 using namespace std;
             5 #define N 10000
             6 int u[N], v[N], w[N], r[N], p[N];
             7 int cmp(int i, int j) {return w[i] < w[j];}
             8 int find(int x) { return p[x] == x ? x : p[x] = find(p[x]); }
             9 int n,m;
            10 int kruskal()
            11 {
            12     int ans=0;
            13     for(int i = 0; i <=n; ++i) p[i] = i;
            14     for(int i = 0; i < m; ++i) r[i] = i;
            15     sort(r,r+m,cmp);
            16     for(int i = 0, cnt  = 0; i < m && cnt < n - 1++i)
            17     {
            18         int e = r[i]; int x  = find(u[e]); int y = find(v[e]);
            19         if(x != y){ ans += w[e]; cnt++; p[x] = y; }
            20     }
            21     return ans;
            22 }
            23 int main()
            24 {
            25     while(scanf("%d"&n),n)
            26     {
            27         m=0;
            28         char c[2];
            29         for(int i = 0; i < n - 1++i)
            30         {
            31             int cnt;
            32             scanf("%s%d", c, &cnt);
            33             for(int j = 0; j < cnt; ++j)
            34             {
            35                 int we;char cc[2];
            36                 scanf("%s%d", cc, &we);
            37                 u[m] = c[0- 'A';
            38                 v[m] = cc[0- 'A';
            39                 w[m] = we;
            40                 m++;
            41             }
            42         }
            43         int ans = kruskal();
            44         printf("%d\n", ans);
            45     }
            46     return 0;
            47 }
            48 
            posted on 2011-09-12 21:40 ACSeed 閱讀(267) 評論(0)  編輯 收藏 引用
            <2011年9月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678

            常用鏈接

            留言簿(1)

            隨筆檔案

            偶像的Blog

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            美女写真久久影院| 国产精品一久久香蕉产线看 | 日本久久久精品中文字幕| 久久久久久人妻无码| AA级片免费看视频久久| 日本久久中文字幕| 精品久久一区二区| 久久99热这里只频精品6| 久久99精品国产麻豆宅宅| 久久精品亚洲福利| 天天躁日日躁狠狠久久| 久久99久久无码毛片一区二区| 久久精品国产99国产精品导航| 成人精品一区二区久久| 国产69精品久久久久久人妻精品| 日本福利片国产午夜久久| 亚洲国产精品无码成人片久久| 国产免费福利体检区久久| 久久久久亚洲AV无码麻豆| 亚洲国产综合久久天堂| 99久久精品免费看国产免费| 中文字幕人妻色偷偷久久| 久久人妻少妇嫩草AV蜜桃| 久久综合狠狠色综合伊人| 久久狠狠高潮亚洲精品| 色偷偷久久一区二区三区| 久久亚洲精品无码aⅴ大香| 久久九九久精品国产免费直播| 亚洲综合精品香蕉久久网97| 97久久精品国产精品青草| 久久人人妻人人爽人人爽| 久久免费看黄a级毛片| 亚洲国产天堂久久综合| 久久久久国产| 久久人人爽人人爽AV片| 久久久久亚洲AV无码专区桃色| 久久九九久精品国产免费直播| 久久91这里精品国产2020| 久久激情五月丁香伊人| 久久影院亚洲一区| 国产香蕉久久精品综合网|