【最小生成树】【kruscal】【贪心】CDOJ1636 梦后楼台高锁,酒醒帘幕低垂

首先,考虑到,我们需要找到一条路径,使它的最小边尽量大,最大边尽量小
然后,考虑到m比较小,我们可以去寻找一个m^2或者m^2logm的算法
考虑枚举最小边,那么我们就需要在m或者mlogm的时间内找到尽量小的最大边
回忆最小生成树的kruskal算法,并查集+贪心加边
应用到此题,从枚举的最小边贪心加边,当1和n属于同一个集合时停止,得出的一定是当前最小边情况下的最优解
#include<cstdio>
#include<algorithm>
using namespace std;
int fa[210];
int find(int x){
return x==fa[x] ? x : fa[x]=find(fa[x]);
}
struct Edge{
int u,v,w;
}es[1010];
bool cmp(const Edge &a,const Edge &b){
return a.w<b.w;
}
int n,m,ans=2147483647;
int main(){
scanf("%d%d",&n,&m);
for(int i=1;i<=m;++i){
scanf("%d%d%d",&es[i].u,&es[i].v,&es[i].w);
}
sort(es+1,es+m+1,cmp);
for(int i=1;i<=m;++i){
for(int j=1;j<=n;++j){
fa[j]=j;
}
bool flag=0;
for(int j=i;j<=m;++j){
int U=find(es[j].u),V=find(es[j].v);
if(U!=V){
fa[U]=V;
}
if(find(1)==find(n)){
flag=1;
ans=min(ans,es[j].w-es[i].w);
break;
}
}
if(!flag){
break;
}
}
printf("%d\n",ans);
return 0;
}
【最小生成树】【kruscal】【贪心】CDOJ1636 梦后楼台高锁,酒醒帘幕低垂的更多相关文章
- CDOJ:1636-梦后楼台高锁,酒醒帘幕低垂(Kruskal+暴力)
		
梦后楼台高锁,酒醒帘幕低垂 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
 - HDU 5253  最小生成树 kruscal
		
Description 老 Jack 有一片农田,以往几年都是靠天吃饭的.但是今年老天格外的不开眼,大旱.所以老 Jack 决定用管道将他的所有相邻的农田全部都串联起来,这样他就可以从远处引水过来进行 ...
 - 【UVA  10307 Killing Aliens in Borg Maze】最小生成树, kruscal, bfs
		
题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=20846 POJ 3026是同样的题,但是内存要求比较严格,并是没有 ...
 - POJ - 2421 Constructing Roads 【最小生成树Kruscal】
		
Constructing Roads Description There are N villages, which are numbered from 1 to N, and you should ...
 - 最小生成树——Kruscal(克鲁斯卡尔算法)
		
一.核心思想  将输入的数据由小到大进行排序,再使用并查集算法(传送门)将每个点连接起来,同时求和.  个人认为这个算法比较偏向暴力,有些题可能会超时. 二.例题 洛谷-P3366 题目地址:ht ...
 - 图论--最小生成树--Kruscal 模板
		
#include<iostream> #include<queue> #include<algorithm> #include<set> #includ ...
 - (step6.1.4)hdu 1102(Constructing Roads——最小生成树)
		
题目大意:输入一个整数n,表示村庄的数目.在接下来的n行中,每行有n列,表示村庄i到村庄 j 的距离.(下面会结合样例说明).接着,输入一个整数q,表示已经有q条路修好. 在接下来的q行中,会给出修好 ...
 - "《算法导论》之‘图’":最小生成树(无向图)
		
本文主要参考自<算法>. 加权图是一种为每条边关联一个权值或是成本的图模型.这种图能够自然地表示许多应用.在一幅航空图中,边表示航线,权值则可以表示距离或是费用.在一幅电路图中,边表示导线 ...
 - CSP 地铁修建 Kruskal (最小生成树+并查集)
		
问题描述 A市有n个交通枢纽,其中1号和n号非常重要,为了加强运输能力,A市决定在1号到n号枢纽间修建一条地铁. 地铁由很多段隧道组成,每段隧道连接两个交通枢纽.经过勘探,有m段隧道作为候选,两个交通 ...
 
随机推荐
- 【HNOI】 c tree-dp
			
[题目描述]给定一个n个节点的树,每个节点有两个属性值a[i],b[i],我们可以在树中选取一个连通块G,这个连通块的值为(Σa[x])(Σb[x]) x∈G,求所有连通块的值的和,输出答案对1000 ...
 - js_如何优化你的代码让它更好看
			
1.对于美的东西我们很难拒绝,比如美女.哈哈哈,程序员的梗. 2.所以我希望我写出来的代码也是很美观的,让人看起来会很舒服. 3.要想让你的代码简约美观,就要涉及封装,模块化了,可复用代码.vue可以 ...
 - linux启动过程——(三)
 - mysql中的时间year/date/time/datetime
			
year: mysql> create table y(y year); Query OK, 0 rows affected (0.03 sec) mysql> desc y; +---- ...
 - SD卡spi读写流程
			
SD卡spi读写流程 1.SD卡的命令格式: SD卡的指令由6字节(Byte)组成,如下: Byte1:0 1 x x x x x x(命令号,由指令标志定义,如CMD39为100111即16进制0x ...
 - 【Android XML】Android XML 转 Java Code 系列之 介绍(1)
			
最近在公司做一个项目,需要把Android界面打包进jar包给客户使用.对绝大部分开发者来说,Android界面的布局以XML文件为主,并辅以少量Java代码进行动态调整.而打包进jar包的代码,意味 ...
 - SqlServer开启CLR使用(C#)DLL实现实时Socket通知
			
--1.默认情况下,SQL Server中的CLR是关闭的,所以我们需要执行如下命令打开CLR: reconfigure GO -- DROP FUNCTION dbo.fnScoketSend -- ...
 - 【codeforces85D】
			
去实验培训回来了……写个题先玩玩 这题给人一种平衡树的感觉 但是呢,实际上操作离线+离散化+线段树一样能做 #include<bits/stdc++.h> #define lson (o& ...
 - [收集]关于MSSQL数据库的一些查询
			
sqlserver快速查找所有存储过程中是否包含某字符 --将XXXX替换成你要查找的内容 select name from sysobjects o, syscomments s where o.i ...
 - php中mvc新建页面
			
PHP配置: <?phpclass appointmentController extends Controller{public function __construct(){parent:: ...