• <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)  編輯 收藏 引用
            潮喷大喷水系列无码久久精品 | 日韩精品久久无码中文字幕| 伊人久久亚洲综合影院| 噜噜噜色噜噜噜久久| 亚洲精品无码久久久久去q | 久久久久久久综合日本| 久久久国产亚洲精品| 1000部精品久久久久久久久| 久久精品一区二区影院| 亚洲第一极品精品无码久久| 狠狠精品久久久无码中文字幕| 日韩欧美亚洲综合久久| 一级做a爱片久久毛片| 日韩精品久久无码人妻中文字幕| 久久99国产精品成人欧美| 久久精品天天中文字幕人妻| 亚洲欧美一级久久精品| 国产成人精品久久| 久久国产精品77777| 久久久久久久波多野结衣高潮| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区| 一本一道久久a久久精品综合| 久久青青草原国产精品免费| 日产精品久久久久久久性色| 久久综合色老色| 中文字幕精品无码久久久久久3D日动漫| 国内精品伊人久久久久| 欧洲成人午夜精品无码区久久| 国产精品久久新婚兰兰 | 亚洲国产精品无码久久久秋霞2 | 久久久这里只有精品加勒比| 国内精品久久久久久久亚洲| 久久综合中文字幕| 久久人人爽爽爽人久久久| 欧美亚洲色综久久精品国产| 久久亚洲精品无码aⅴ大香| 人人妻久久人人澡人人爽人人精品| 欧美日韩精品久久久久| 香蕉久久夜色精品国产尤物| 久久精品中文字幕大胸| 一本色道久久综合狠狠躁|