https://www.luogu.org/problem/show?pid=2330#sub

题目描述

城市C是一个非常繁忙的大都市,城市中的道路十分的拥挤,于是市长决定对其中的道路进行改造。城市C的道路是这样分布的:城市中有n个交叉路口,有些交叉路口之间有道路相连,两个交叉路口之间最多有一条道路相连接。这些道路是双向的,且把所有的交叉路口直接或间接的连接起来了。每条道路都有一个分值,分值越小表示这个道路越繁忙,越需要进行改造。但是市政府的资金有限,市长希望进行改造的道路越少越好,于是他提出下面的要求:

1.改造的那些道路能够把所有的交叉路口直接或间接的连通起来。

2.在满足要求1的情况下,改造的道路尽量少。

3.在满足要求1、2的情况下,改造的那些道路中分值最大的道路分值尽量小。

任务:作为市规划局的你,应当作出最佳的决策,选择那些道路应当被修建。

输入输出格式

输入格式:

第一行有两个整数n,m表示城市有n个交叉路口,m条道路。接下来m行是对每条道路的描述,u, v, c表示交叉路口u和v之间有道路相连,分值为c。(1≤n≤300,1≤c≤10000)

输出格式:

两个整数s, max,表示你选出了几条道路,分值最大的那条道路的分值是多少。

输入输出样例

输入样例#1:

4 5
1 2 3
1 4 5
2 4 7
2 3 6
3 4 8
输出样例#1:

3 6

裸kruskal
 #include <algorithm>
#include <iostream> using namespace std; int n,m,u,v,w;
int max_use,sum;
int fa[]; struct node_edge
{
int u,v,w;
}edge[]; bool cmp(node_edge a,node_edge b)
{
return a.w<b.w;
} int find(int x)
{
return fa[x]==x?x:fa[x]=find(fa[x]);
} void kruskal()
{
for(int i=;i<=m;i++)
{
int fx=find(edge[i].u);
int fy=find(edge[i].v);
if(fx!=fy)
{
sum++;
fa[fx]=fy;
max_use=max(max_use,edge[i].w);
}
if(sum==n-) return ;
}
} int main()
{
cin>>n>>m;
for(int i=;i<=n;i++) fa[i]=i;
for(int i=;i<=m;i++)
{
cin>>u>>v>>w;
edge[i].u=u;
edge[i].v=v;
edge[i].w=w;
}
sort(edge+,edge+m+,cmp);
kruskal();
cout<<sum<<" "<<max_use;
return ;
}

最新文章

  1. WriteLog
  2. table tr foreach td 换行
  3. 怎么在js中,访问viewbag,viewdata等等的值
  4. Android 中的常用方法
  5. Linux环境PHP5.5以上连接SqlServer2008【全网最经典无错版】
  6. MyEclipse for Spring启动时报错&quot;An internal error occurred during: &#39;Updating indexes&#39;.Java heap space&quot;的解决办法
  7. xcode5 和code6中push后方法执行的先后问题
  8. 2208: [Jsoi2010]连通数
  9. Python之numpy模块array简短学习
  10. 「LOJ2000~2023」各省省选题选做
  11. 关于.NetCore 2.0 迁移到2.1的一些建议和问题
  12. Android内存机制分析——堆和栈
  13. M端错误提醒 -- pop 使用
  14. CYUSB3014固件部分低版本工程在Eclipse中编译得到img文件时无效的解决方案
  15. VC中TRACE ASSERT VERIFY之用法
  16. Codeforces 1082 D. Maximum Diameter Graph-树的直径-最长链-构造题 (Educational Codeforces Round 55 (Rated for Div. 2))
  17. Linux vi 文件编辑
  18. Introduction to Mathematical Thinking - Week 4
  19. angular-cli.json配置参数解析,常用命令解析
  20. vue中background-image图片路径问题

热门文章

  1. P4046 [JSOI2010]快递服务
  2. [Apple开发者帐户帮助]七、注册设备(1)注册一个设备
  3. 【BZOJ4241】历史研究(回滚莫队)
  4. Hadoop Hive概念学习系列之hive的脚本执行(二十)
  5. 生成错误:对路径&quot;.dll&quot;的访问被拒绝
  6. Java中的异常注意点
  7. 使用XUL开发跨平台桌面应用
  8. 汇总——WEB前端资源网
  9. eclipse中代码整体左右移动的方法
  10. (转)Arcgis for JS之Cluster聚类分析的实现