博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
畅通工程(kruskal算法)
阅读量:5103 次
发布时间:2019-06-13

本文共 1529 字,大约阅读时间需要 5 分钟。

个人心得:日了狗,WR了俩个小时才发现是少了个vector清理,我也是醉了,不过后面还是对这个有了更好得了解,一是我得算法,而是学长改进

后的算法,改进后得算法还要判断所有村庄是否在连在一起,其实我觉得实必要性不大。

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

 

 

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
2 #include
3 #include
4 #include
5 #include
6 using namespace std; 7 const long long maxa=99999999; 8 int n,m; 9 struct village10 {11 int v;12 int e;13 int w;14 village(int x,int y,int z){15 v=x,e=y,w=z;16 }17 village(){}18 bool operator <(const village &V)const19 {20 return w
V;26 int book[105];27 void init()28 {29 for(int i=1;i<=m;i++)30 book[i]=i;31 32 }33 int getx(int x)34 {35 if(book[x]!=x)36 book[x]=getx(book[x]);37 return book[x];38 }39 void mergexy(int x,int y)40 {41 book[y]=x;42 }43 int main()44 {45 while(cin>>n>>m)46 {47 V.clear();48 if(n==0) break;49 init();50 int t=n;51 while(t--)52 {53 int x,y,z;54 scanf("%d%d%d",&x,&y,&z);55 village a(x,y,z);56 V.push_back(a);57 }58 sort(V.begin(),V.end());59 int number=0;60 long long sum=0;61 for(int i=0;i

 

转载于:https://www.cnblogs.com/blvt/p/7300914.html

你可能感兴趣的文章
php match_model的简单使用
查看>>
在NT中直接访问物理内存
查看>>
Intel HEX 文件格式
查看>>
SIP服务器性能测试工具SIPp使用指导(转)
查看>>
php_扑克类
查看>>
回调没用,加上iframe提交表单
查看>>
(安卓)一般安卓开始界面 Loding 跳转 实例 ---亲测!
查看>>
Mysql 索引优化 - 1
查看>>
LeetCode(3) || Median of Two Sorted Arrays
查看>>
大话文本检测经典模型:EAST
查看>>
linux基础命令-chgrp/chown/chomd
查看>>
待整理
查看>>
一次动态sql查询订单数据的设计
查看>>
C# 类(10) 抽象类.
查看>>
Nginx+Keepalived 实现双击热备及负载均衡
查看>>
Vue_(组件通讯)子组件向父组件传值
查看>>
jvm参数
查看>>
Something-Summary
查看>>
Spring学习笔记
查看>>
6个有用的MySQL语句
查看>>