Slim Span (最小生成树)
题意
求生成树的最长边与最短边的差值的最小值
题解
最小生成树保证每一条边最小,就只要枚举最小边开始,跑最小生成树,最后一个值便是最大值
在枚举最小边同时维护差值最小,不断更新最小值。
C++代码
/**
/*@author Victor
/*language C++
*/
#include <bits/stdc++.h>
#include<iostream>
#include<algorithm>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<string>
#include<vector>
#include<bitset>
#include<queue>
#include<deque>
#include<stack>
#include<cmath>
#include<list>
#include<map>
#include<set>
//#define DEBUG
#define RI register int
using namespace std;
typedef long long ll;
//typedef __int128 lll;
const int N=+;
const int MOD=1e9+;
const double PI = acos(-1.0);
const double EXP = 1E-;
const int INF = 0x3f3f3f3f;
#define pii pair<int,int>
#define pll pair<ll,ll>
#define pil pair<int , ll>
#define pli pair<ll,int>
#define pdl pair<double,ll>
#define pld pair<ll,double>
#define pdd pair<double,double>
#define iput(n) scanf("%d",&n);
#define dput(n) scanf("%lf",&n);
#define llput(n) scanf("%lld",&n);
#define cput(n) scanf("%s",n);
#define puti(n) printf("%d\n",n);
#define putll(n) printf("%lld\n",n);
#define putd(n) printf("%lfd\n",n);
#define _cls(n) memset(n,0,sizeof(n));
//求二进制中1的个数
//__builtin_popcount(n);
//求2^k
//#define (ll)Pow(2,k) (1LL<<k) struct edge
{
int u,v,cost;
}eg[];
int n,m;//,father[100001]; bool cmp(edge e1,edge e2)
{
return e1.cost<e2.cost;
} int par[N]; //父亲
int Rank[N]; //树的高度 //初始化n个元素
void init(int n)
{
for(int i=; i<=n; ++i)
{
par[i] = i;
Rank[i] = ;
}
}
//查询树的根非递归实现
int find(int x)
{
while(par[x]!=x)
x=par[x];
return x;
}
//合并x和y所属集合
void unite(int x,int y)
{
int fx=find(x);
int fy=find(y);
if(fx==fy)
return;
if(Rank[fx]>Rank[fy])
par[fx]=fy;
else
{
par[fy]=fx;
if(Rank[fx]==Rank[fy])
Rank[x]++;
}
}
//关于路径压缩
int find2(int x)
{
int fx=find(x);
int t;
while(x!=fx)
{
t=par[x];
par[x]=fx;
x=t;
}
return fx;
} // 最小生成树 Kruskal 算法
int minn;
int Kruskal()
{
minn = 1e9;
edge e;
int i,res;
sort(eg,eg+m,cmp);
// 构建最小生成树
for(int j = ;j < m; j ++){ init(n);res=; for( i=j;i<m;++i )
{
e=eg[i];
if( find(e.u)!=find(e.v) )
{
unite(e.u,e.v); if(++res == n - )
minn = min(minn,e.cost - eg[j].cost);
}
}
}
return res;
} int main(){ while(scanf("%d%d",&n,&m)&&n+m){ for(int i = ; i < m;++i){
scanf("%d%d%d",&eg[i].u,&eg[i].v,&eg[i].cost);
}
int ans = Kruskal();
bool flag = ; if(minn != ) printf("%d\n",minn);
else printf("-1\n");
}
}
Slim Span (最小生成树)的更多相关文章
- poj 3522 Slim Span (最小生成树kruskal)
		http://poj.org/problem?id=3522 Slim Span Time Limit: 5000MS Memory Limit: 65536K Total Submissions ... 
- POJ 3522 Slim Span 最小生成树,暴力 难度:0
		kruskal思想,排序后暴力枚举从任意边开始能够组成的最小生成树 #include <cstdio> #include <algorithm> using namespace ... 
- uva1395 - Slim Span(最小生成树)
		先判断是不是连通图,不是就输出-1. 否则,把边排序,从最小的边开始枚举最小生成树里的最短边,对每个最短边用Kruskal算法找出最大边. 或者也可以不先判断连通图,而是在枚举之后如果ans还是INF ... 
- UVA 1395	Slim Span 最小生成树
		题意: 给你一个图,让你求这个图中所有生成树中满足题目条件的,这个条件是生成树中最长边与最短边的差值最小. 思路: 根据最小瓶颈生成树的定义:在一个有权值的无向图中,求一个生成树最大边的权值尽量小.首 ... 
- UVA 1395 Slim Span (最小生成树,MST,kruscal)
		题意:给一个图,找一棵生成树,其满足:最大权-最小权=最小.简单图,不一定连通,权值可能全相同. 思路:点数量不大.根据kruscal每次挑选的是最小权值的边,那么苗条度一定也是最小.但是生成树有多棵 ... 
- 最小生成树POJ3522 Slim Span[kruskal]
		Slim Span Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 7594 Accepted: 4029 Descrip ... 
- POJ 3522 Slim Span(极差最小生成树)
		Slim Span Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 9546 Accepted: 5076 Descrip ... 
- POJ 3522 ——Slim Span——————【最小生成树、最大边与最小边最小】
		Slim Span Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 7102 Accepted: 3761 Descrip ... 
- POJ-3522 Slim Span(最小生成树)
		Slim Span Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 8633 Accepted: 4608 Descrip ... 
随机推荐
- 定时器的写法 winform
			private void timer1_Tick(object sender, EventArgs e) { if ( tttttflag) { Action action = SyncCompany ... 
- PHP基础教程 php 网络上关于设计模式一些总结
			1.单例模式 单例模式顾名思义,就是只有一个实例.作为对象的创建模式,单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 单例模式的要点有三个: 一是某个类只能有一个实例; 二 ... 
- BZOJ 1901 洛谷 P2617 ZOJ 2112 Dynamic Rankings
			以下时空限制来自zoj Time limit 10000 ms Memory limit 32768 kB OS Linux Source Online Contest of Christopher' ... 
- jenkins 打标签实现回滚
			背景介绍: 本项目代码存储在gitlab,再通过jenkins发布到对应的节点上. 使用tag控制版本:每一次成功的构建,jenkins会自动为gitlab的分支打上tag,版本更新可直接选择prod ... 
- 3D Computer Grapihcs Using OpenGL - 18 相机移动
			移动相机需要用到键盘按键,按键事件的引入需要包含头文件 #include <Qt3DInput\qkeyevent.h> 并实现QWidget中定义的虚函数keyPressEvent 我们 ... 
- [CSP-S模拟测试]:maze(二分答案+最短路)
			题目传送门(内部题88) 输入格式 第一行两个数$n,m$.第二行四个数$sx,sy,tx,ty$.分别表示起点所在行数.列数,终点所在行数.列数.接下来$n$行,每行$m$个数,描述迷宫.最后一行一 ... 
- bootstrap editable 行内编辑
			除了那些bootstrap/bootstrap table的js , css之外,要额外添加editable的文件: <link href="../assets/css/bootstr ... 
- centos7 修改ali yum源
			centos7 修改yum源为阿里源,某下网络下速度比较快 首先是到yum源设置文件夹里 安装base reop源 cd /etc/yum.repos.d 接着备份旧的配置文件 sudo mv Cen ... 
- Oracle开发:normal ,sysdba,sysoper区别
			Oracle将用户分成两类:[system]和[sys] [system]用户只能用normal身份登陆em.(可以看成公司的普通成员) [sys]用户具有“SYSDBA”(可以看成公司的CEO)或者 ... 
- HyperV - glossary
			Root Partition - sometimes called partition. Manages machine-level functions such as device drivers, ... 
