zoukankan      html  css  js  c++  java
  • 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
    ",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
  • 相关阅读:
    hdu 1754 线段树 注意线段树节点的设计 求什么,设什么
    hdu 4015 概率题
    poj 1950 回溯
    最大上升子序列
    JVM学习博客
    2012
    i am alone at a crossroads
    易知难
    牢骚。。
    something
  • 原文地址:https://www.cnblogs.com/crackpotisback/p/3941125.html
Copyright © 2011-2022 走看看