[hdu5253] 最小生成树,Kruskal
题意:有n*m个单位的农田,给定每个单位农田地势高低,现在需要灌溉所有农田,如果把水引入相邻的农田里需要的管道长度为两者的高度差。求最少的管道长度花费。
思路:比较明显的最小生成树问题,相邻两点之间连一条边,边权为高度之差,求图的最小生成树即可。由于高度范围只有100,故可以直接类似hash表存了,无需排序。
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 | #include <iostream>#include <cstdio>#include <cstring>#include <cstdlib>#include <vector>#include <cmath>#include <algorithm>usingnamespacestd;vector<pair<int, int> > C[101];intfa[1234567], a[1234567];intget_id(intx, inty, intn) { returnx * n + y; }voidadd(intu, intv) {    intdif = abs(a[u] - a[v]);    C[dif].push_back(make_pair(u, v));}intgetfa(intu) { returnu == fa[u]? u : fa[u] = getfa(fa[u]); }intmain() {#ifndef ONLINE_JUDGE    freopen("in.txt", "r", stdin);#endif // ONLINE_JUDGE    intT;    cin >> T;    for(intcas = 1; cas <= T; cas ++) {        intn, m;        cin >> n >> m;        for(inti = 0; i < 101; i ++) C[i].clear();        for(inti = 0; i < n * m; i ++) fa[i] = i;        for(inti = 0; i < n; i ++) {            for(intj = 0; j < m; j ++) {                scanf("%d", a + get_id(i, j, m));                if(i) add(get_id(i, j, m), get_id(i - 1, j, m));                if(j) add(get_id(i, j, m), get_id(i, j - 1, m));            }        }        intcnt = 0, ans = 0;        for(inti = 0; i < 101; i ++) {            intsz = C[i].size();            for(intj = 0; j < sz; j ++) {                intu = C[i][j].first, v = C[i][j].second;                intfu = getfa(u), fv = getfa(v);                if(fu != fv) {                    ans += i;                    cnt ++;                    fa[fu] = fv;                    if(cnt == n * m - 1) gotoEND;                }            }        }        END:        printf("Case #%d:\n", cas);        cout << ans << endl;    }    return0;} | 
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号