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

            A Za, A Za, Fighting...

            堅信:勤能補拙

            PKU 1861 Network/PKU 2485 Highways

            問題:
            http://acm.pku.edu.cn/JudgeOnline/problem?id=1861
            http://acm.pku.edu.cn/JudgeOnline/problem?id=2485

            思路:
            這里題目并沒有明確要求求最小生成樹,而是要求一顆最長邊最小的生成樹
            我們可以證明:
                   如果T是一顆最小生成樹,那么T所包含的最長邊一定是所有生成樹中最小的,即最小生成樹滿足題目要求
            Prove:
            如果T的最長邊(x, y)并非最小
            那么,存在一顆生成樹R,其最長邊(u, v)<(x, y),即生成樹R的任何一條邊都小于(x, y)
            現在,采用剪切-粘帖的方法來證明T不是一顆最小生成樹,即矛盾
            將T中的最長邊(x, y)剪切掉,這樣就得到兩顆子樹
            在R中,至少存在一條邊(p, q)可以將這兩顆子樹連接起來,這樣就得到:
                       T - (x, y) + (p, q) < T

            代碼(這里采用Kruskal算法,并查集實現)
             1 /* union-find sets, Kruskal algorithm */
             2 #include<stdio.h>
             3 #include<stdlib.h>
             4 #include<string.h>
             5 #define MAX_N 1001
             6 #define MAX_M 15001
             7 struct Edge{
             8     int len;
             9     int from, to;
            10 }edges[MAX_M];
            11 int parent[MAX_N], rank[MAX_N];
            12 int n, m;
            13 
            14 void
            15 make_set()
            16 {
            17     int i;
            18     for(i=1; i<=n; i++)
            19         parent[i] = i;
            20     memset(rank, 0sizeof(rank));
            21 }
            22 
            23 int
            24 find(int x)
            25 {
            26     int tmp, rt = x;
            27     while(parent[rt] != rt)
            28         rt = parent[rt];
            29     while(x != rt) {
            30         tmp = parent[x];
            31         parent[x] = rt;
            32         x = tmp;
            33     }
            34     return rt;
            35 }
            36 
            37 void
            38 Union(int x, int y)
            39 {
            40     int a = find(x);
            41     int b = find(y);
            42     if(a == b)
            43         return;
            44     if(rank[a] > rank[b])
            45         parent[b] = a;
            46     else {
            47         parent[a] = b;
            48         if(rank[a] == rank[b])
            49             ++rank[b];
            50     }
            51 }
            52 
            53 int
            54 compare(const void *arg1, const void *arg2)
            55 {
            56     return ((struct Edge *)arg1)->len - ((struct Edge *)arg2)->len;
            57 }
            58 
            59 void
            60 init()
            61 {
            62     int i;
            63     for(i=0; i<m; i++
            64         scanf("%d %d %d"&edges[i].from, &edges[i].to, &edges[i].len);
            65     qsort(edges, m, sizeof(struct Edge), compare);
            66 }
            67 
            68 void
            69 kruskal()
            70 {
            71     int i, a, b, count = 0;
            72     int mark[MAX_N];
            73     make_set();
            74     for(i=0; i<m; i++) {
            75         a = find(edges[i].from);
            76         b = find(edges[i].to);
            77         if(a != b) {
            78             mark[count++= i;
            79             Union(a, b);
            80         }
            81     }
            82     /* output */
            83     printf("%d\n", edges[mark[count-1]].len);
            84     printf("%d\n", count);
            85     for(i=0; i<count; i++)
            86         printf("%d %d\n", edges[mark[i]].from, edges[mark[i]].to);
            87 }
            88 
            89 int
            90 main(int argc, char **argv)
            91 {
            92     while(scanf("%d %d"&n, &m) != EOF) {
            93         init();
            94         kruskal();
            95     }
            96 }


            posted on 2010-09-05 13:09 simplyzhao 閱讀(197) 評論(0)  編輯 收藏 引用 所屬分類: F_圖算法

            導航

            <2010年10月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            統計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产精品一久久香蕉产线看| 77777亚洲午夜久久多喷| 久久九九全国免费| 久久久久一级精品亚洲国产成人综合AV区| 久久精品国产亚洲AV香蕉| 国产精品久久久久久久| 久久久91人妻无码精品蜜桃HD| 性做久久久久久久久老女人| 国产一区二区久久久| AV色综合久久天堂AV色综合在| 伊人热人久久中文字幕| 久久久这里只有精品加勒比| 三上悠亚久久精品| 国产免费久久精品丫丫| 久久久久久亚洲精品成人| 老司机午夜网站国内精品久久久久久久久 | 99精品久久精品一区二区| 久久成人影院精品777| 精品久久久无码人妻中文字幕| 久久精品国产影库免费看| 精品久久久一二三区| 亚洲一区中文字幕久久| 亚洲综合精品香蕉久久网| 久久本道综合久久伊人| 色成年激情久久综合| 久久综合狠狠综合久久综合88 | 一级女性全黄久久生活片免费| 丁香狠狠色婷婷久久综合| 人妻精品久久无码区| 日产久久强奸免费的看| 美女写真久久影院| 国内精品久久久久久野外| 无码日韩人妻精品久久蜜桃| 亚洲精品视频久久久| 久久国产精品国语对白| 国产精品伦理久久久久久| 国产精品久久久福利| 亚洲嫩草影院久久精品| 久久99精品国产麻豆宅宅| 久久精品国产免费| 老司机国内精品久久久久|