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

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲人成电影网站久久| 91精品国产综合久久香蕉| 精品国际久久久久999波多野| 国产V亚洲V天堂无码久久久| 伊人久久大香线蕉综合Av| 综合久久一区二区三区 | 久久精品一区二区国产| 综合网日日天干夜夜久久| 亚洲AV日韩精品久久久久久| 精品久久久噜噜噜久久久| 国内精品久久九九国产精品| 国产精品美女久久久久av爽| 欧美与黑人午夜性猛交久久久| 亚洲人成电影网站久久| 久久综合久久综合九色| 亚洲国产精品无码久久久蜜芽| 99久久精品日本一区二区免费| 久久国产乱子伦精品免费午夜| 久久久久人妻精品一区二区三区| 久久久精品人妻无码专区不卡| 精品久久久久久中文字幕人妻最新| 精品久久久久久无码人妻热| 日本精品久久久中文字幕| 99久久婷婷免费国产综合精品| 亚洲成色www久久网站夜月| 无码八A片人妻少妇久久| 一本综合久久国产二区| 青青热久久国产久精品| 亚洲国产成人久久综合碰| 亚洲国产成人精品91久久久 | 久久A级毛片免费观看| 2021国内久久精品| 精品无码久久久久国产动漫3d | 久久se这里只有精品| 久久久91人妻无码精品蜜桃HD| 色综合久久天天综合| 香蕉久久夜色精品国产2020| 综合久久国产九一剧情麻豆| 久久成人影院精品777| 99久久婷婷国产一区二区| 久久人做人爽一区二区三区|