• <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 閱讀(269) 評論(0)  編輯 收藏 引用
            <2011年9月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678

            常用鏈接

            留言簿(1)

            隨筆檔案

            偶像的Blog

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久国产一区二区| 亚洲国产精品成人久久| 久久精品免费观看| 性做久久久久久久久久久| 久久激情五月丁香伊人| 成人资源影音先锋久久资源网| 99久久综合国产精品免费| 无码AV中文字幕久久专区| 久久亚洲精品成人av无码网站| 欧美熟妇另类久久久久久不卡| 精品国产青草久久久久福利| 欧美大香线蕉线伊人久久| 国产精品久久久久影视不卡| 人妻丰满AV无码久久不卡| 香蕉久久久久久狠狠色| 国产精品热久久无码av| 色狠狠久久AV五月综合| 久久综合九色欧美综合狠狠| 91久久国产视频| 一本伊大人香蕉久久网手机| 高清免费久久午夜精品| 久久青草国产手机看片福利盒子| 亚洲日韩中文无码久久| 日韩人妻无码精品久久久不卡| 久久夜色撩人精品国产| 色狠狠久久综合网| 久久久久无码精品国产不卡| AV无码久久久久不卡网站下载| 大香伊人久久精品一区二区| 国产亚洲精久久久久久无码77777 国产亚洲精品久久久久秋霞 | 久久国产香蕉视频| 久久中文字幕人妻熟av女| 久久精品国产亚洲AV高清热| 国产美女久久久| 久久有码中文字幕| 99久久久国产精品免费无卡顿| 久久99精品久久久久久水蜜桃| 久久这里的只有是精品23| 久久99精品久久久久久hb无码 | 97久久精品无码一区二区天美| 国产精品欧美亚洲韩国日本久久|