• <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
            今天做了幾道最小生成樹的初級題,不過只學(xué)習(xí)了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)  編輯 收藏 引用

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


            <2011年9月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678

            常用鏈接

            留言簿(1)

            隨筆檔案

            偶像的Blog

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            九九久久自然熟的香蕉图片| 日本免费久久久久久久网站| 久久天天躁夜夜躁狠狠| 国产午夜福利精品久久2021| 国产精品久久一区二区三区| 狠狠色噜噜色狠狠狠综合久久| 亚洲一区二区三区日本久久九| 久久精品国产男包| 精品久久久久久国产91| 日韩精品久久久肉伦网站| 欧美亚洲国产精品久久| 香蕉久久久久久狠狠色| 久久精品女人天堂AV麻| 久久久久国产| 色偷偷久久一区二区三区| 久久久久亚洲AV无码专区桃色| 精品国产一区二区三区久久蜜臀| 情人伊人久久综合亚洲| 久久精品国产亚洲77777| 久久久中文字幕| 久久精品黄AA片一区二区三区| 亚洲国产成人精品无码久久久久久综合| 少妇高潮惨叫久久久久久| 亚洲第一极品精品无码久久| 人妻无码久久精品| 久久人搡人人玩人妻精品首页| 97久久精品国产精品青草| 久久久久女人精品毛片| 无码国内精品久久综合88 | 97精品依人久久久大香线蕉97| 国内精品久久久久久久coent| 久久综合综合久久97色| 99久久无码一区人妻a黑| 996久久国产精品线观看| 久久婷婷国产综合精品 | 国产一级持黄大片99久久| 精品久久久久久成人AV| 国产成人精品久久二区二区 | 99热都是精品久久久久久| 综合久久精品色| 久久热这里只有精品在线观看|