HDU 1836 畅通工程

畅通工程

Time Limit: 1000ms
Memory Limit: 32768KB
This problem will be judged on HDU. Original ID: 1863
64-bit integer IO format: %I64d      Java class name: Main
 
 
省政府“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可)。经过调查评估,得到的统计表中列出了有可能建设公路的若干条道路的成本。现请你编写程序,计算出全省畅通需要的最低成本。
 

Input

测试输入包含若干测试用例。每个测试用例的第1行给出评估的道路条数 N、村庄数目M ( < 100 );随后的 N 
行对应村庄间道路的成本,每行给出一对正整数,分别是两个村庄的编号,以及此两村庄间道路的成本(也是正整数)。为简单起见,村庄从1到M编号。当N为0时,全部输入结束,相应的结果不要输出。
 

Output

对每个测试用例,在1行里输出全省畅通需要的最低成本。若统计数据不足以保证畅通,则输出“?”。
 

Sample Input

3 3
1 2 1
1 3 2
2 3 4
1 3
2 3 2
0 100

Sample Output

3
?

Source

 
解题:最小生成树。
 
 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <cmath>
 5 #include <algorithm>
 6 #include <climits>
 7 #include <vector>
 8 #include <queue>
 9 #include <cstdlib>
10 #include <string>
11 #include <set>
12 #include <stack>
13 #define LL long long
14 #define pii pair<int,int>
15 #define INF 0x3f3f3f3f
16 using namespace std;
17 int mp[110][110],m,n,d[110];
18 priority_queue< pii,vector< pii >,greater< pii > >q;
19 bool done[110];
20 void prim(){
21     while(!q.empty()) q.pop();
22     for(int i = 1; i <= n; i++){
23         d[i] = mp[1][i];
24         done[i] = false;
25         q.push(make_pair(d[i],i));
26     }
27     bool flag = true;
28     int ans = 0;
29     done[1] = true;
30     while(!q.empty()){
31         int u = q.top().second;
32         int w = q.top().first;
33         q.pop();
34         if(done[u]) continue;
35         done[u] = true;
36         if(w >= INF){flag = false;break;}
37         ans += w;
38         for(int i = 1; i <= n; i++){
39             if(d[i] > mp[u][i]){
40                 d[i] = mp[u][i];
41                 q.push(make_pair(d[i],i));
42             }
43         }
44     }
45     if(flag) printf("%d\n",ans);
46     else puts("?");
47 }
48 int main() {
49     int i,j,u,v,w;
50     while(scanf("%d",&m),m){
51         scanf("%d",&n);
52         for(i = 0; i <= n; i++){
53             for(j = 0; j <= n; j++)
54                 mp[i][j] = INF;
55         }
56         for(i = 0; i < m; i++){
57             scanf("%d %d %d",&u,&v,&w);
58             mp[u][v] = mp[v][u] = w;
59         }
60         prim();
61     }
62     return 0;
63 }
View Code

 

posted @ 2014-08-28 11:03  狂徒归来  阅读(209)  评论(0编辑  收藏  举报