畅通工程

来源:互联网 发布:mysql怎么查看表空间 编辑:程序博客网 时间:2024/05/21 11:34

点击打开链接


问题:


畅通工程

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 31413    Accepted Submission(s): 13842


Problem Description
省政府“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可)。经过调查评估,得到的统计表中列出了有可能建设公路的若干条道路的成本。现请你编写程序,计算出全省畅通需要的最低成本。
 

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

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

Sample Input
3 31 2 11 3 22 3 41 32 3 20 100
 

Sample Output
3?
 

Source
浙大计算机研究生复试上机考试-2007年  



AC  代码:



#include <iostream>  #include <cstdio>  #include <cstring>  #include <algorithm>  using namespace std;  int fa[105];  struct node  {      int s,e,w;  }a[5005];  int n,m;  bool cmp(node a,node b)  {      return a.w<b.w;  }  int Find(int x)  {      int r=x;    while(fa[r]!=r)    r=fa[r];    return r;  }    int Kruskal()  {      int ans=0;      for(int i=1;i<=n;i++)          fa[i]=i;      sort(a+1,a+m+1,cmp);      for(int i=1;i<=m;i++)      {          int x=Find(a[i].s);          int y=Find(a[i].e);          if(x!=y)          {              ans+=a[i].w;              fa[x]=y;          }      }      return ans;  }    int main()  {      while(cin>>m>>n,m)      {          for(int i=1;i<=m;i++)          {              scanf("%d%d%d",&a[i].s,&a[i].e,&a[i].w);          }          int ans=Kruskal();          int cnt=0;          for(int i=1;i<=n;i++)          {              if(fa[i]==i)                  cnt++;          }          if(cnt>1)              cout<<"?"<<endl;          else              cout<<ans<<endl;      }      return 0;  }  































原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 自动挡的车如果刹车失灵怎么办 手动挡汽车刹车失灵怎么办 车辆没有年检出了交通事故怎么办 跟着大货车闯了红灯怎么办 在万家金服买的电子产品坏了怎么办 汽车被油笔画了怎么办? 挂到别人车跑了怎么办 浪琴手表保修卡掉了怎么办 事故车辆维修和报废怎么办 4.2货车拉缸了怎么办 工作中与同事发生矛盾怎么办 和领导关系闹僵怎么办 内倒窗户卡住了怎么办 支付宝存在安全风险怎么办 地铁车站空调坏了怎么办 面试防汛值班发生灾情你怎么办 怀孕上班路途太远怎么办 硕士错过校招应该怎么办 收银员收多了钱怎么办 商铺贷款批不了怎么办 铁路局的门面乱收房租怎么办 酒店夜审房费多过怎么办 夜审房价录多了怎么办 做工地拿不到钱怎么办 赢了官司拿不到钱怎么办 工地上拿不到钱怎么办 做了工拿不到钱怎么办 高速公路上车没油了怎么办 高铁乘务员年龄大了怎么办 总公司跑路了分公司怎么办 坐车久了耳朵懵怎么办 过完隧道耳朵疼怎么办 护照还在大使馆需要出国怎么办 护照在大使馆不返回怎么办 美国面签迟到了怎么办 成都美签迟到了怎么办 签证电调没人接怎么办 单位没有抬头纸怎么办在职证明 出国签证无银行流水怎么办 铁路职工得癌症后工作怎么办 去泰国不会泰语和英语怎么办