Kruskal 模板
最小生成树指的是在图上面找到权值最小的一棵树,并且保证图上所有的点都在这棵树上。
解决办法:Kruskal 算法(贪心思想)
将边按权值从小到大排序,然后按这个顺序不断连边,直到所有点联通。
/**
* Fuck you.
* I love you too.
*/
#include<bits/stdc++.h>
#define lson i<<2
#define rson i<<2|1
#define LS l,mid,lson
#define RS mid+1,r,rson
#define mem(a,x) memset(a,x,sizeof(a))
#define gcd(a,b) __gcd(a,b)
#define ll long long
#define ull unsigned long long
#define lowbit(x) (x&-x)
#define enld endl
#define mian main
#define itn int
#define prinft printf
const double PI = acos (-1.0);
const int INF = 0x3f3f3f3f;
const int EXP = 1e-8;
const int N = 1e5 + 5;
const int MOD = 1e9 + 7;
const int MAXN = 1e5 + 5;
using namespace std;
int n;
int ans;
int par[N];
struct ed {
int s, e, cost;
} edge[MAXN];
bool cmp (ed a, ed b) {
return a.cost < b.cost;
}
int Find (int a) {
return a == par[a] ? a : par[a] = Find (par[a]);
}
void join (int a, int b) {
par[Find (a)] = Find (b);
}
int main() {
while (~scanf ("%d", &n)) {
ans = 0;
for (int i = 0; i < n; ++i) {
scanf ("%d%d%d", &edge[i].s, &edge[i].e, &edge[i].cost);
par[edge[i].s] = edge[i].s;
par[edge[i].e] = edge[i].e;
}
sort (edge, edge + n, cmp);
for (int i = 0; i < n; ++i) {
if (Find (edge[i].s) != Find (edge[i].e)) {
cout << edge[i].s << ' ' << edge[i].e << endl;
join (edge[i].s, edge[i].e);
ans += edge[i].cost;
}
}
cout << ans << endl;
}
return 0;
}
Hdu - 1162 Eddy's picture (完全图)
/**
* Fuck you.
* I love you too.
*/
#include<bits/stdc++.h>
#define lson i<<2
#define rson i<<2|1
#define LS l,mid,lson
#define RS mid+1,r,rson
#define mem(a,x) memset(a,x,sizeof(a))
#define gcd(a,b) __gcd(a,b)
#define ll long long
#define ull unsigned long long
#define lowbit(x) (x&-x)
#define enld endl
#define mian main
#define itn int
#define prinft printf
const double PI = acos (-1.0);
const int INF = 0x3f3f3f3f;
;
;
;
;
using namespace std;
int n;
int ans;
int par[N];
struct ed {
int s, e, cost;
} edge[MAXN];
bool cmp (ed a, ed b) {
return a.cost < b.cost;
}
int Find (int a) {
return a == par[a] ? a : par[a] = Find (par[a]);
}
void join (int a, int b) {
par[Find (a)] = Find (b);
}
int main() {
while (~scanf ("%d", &n)) {
ans = ;
; i < n; ++i) {
scanf ("%d%d%d", &edge[i].s, &edge[i].e, &edge[i].cost);
par[edge[i].s] = edge[i].s;
par[edge[i].e] = edge[i].e;
}
sort (edge, edge + n, cmp);
; i < n; ++i) {
if (Find (edge[i].s) != Find (edge[i].e)) {
cout << edge[i].s << ' ' << edge[i].e << endl;
join (edge[i].s, edge[i].e);
ans += edge[i].cost;
}
}
cout << ans << endl;
}
;
}
Hdu - 1233 还是畅通工程(将上面的模板添加一行即可AC)
/**
* Fuck you.
* I love you too.
*/
#include<bits/stdc++.h>
#define lson i<<2
#define rson i<<2|1
#define LS l,mid,lson
#define RS mid+1,r,rson
#define mem(a,x) memset(a,x,sizeof(a))
#define gcd(a,b) __gcd(a,b)
#define ll long long
#define ull unsigned long long
#define lowbit(x) (x&-x)
#define enld endl
#define mian main
#define itn int
#define prinft printf
const double PI = acos (-1.0);
const int INF = 0x3f3f3f3f;
;
;
;
;
using namespace std;
int n;
int ans;
int par[N];
struct ed {
int s, e, cost;
} edge[MAXN];
bool cmp (ed a, ed b) {
return a.cost < b.cost;
}
int Find (int a) {
return a == par[a] ? a : par[a] = Find (par[a]);
}
void join (int a, int b) {
par[Find (a)] = Find (b);
}
int main() {
) {
ans = ;
n = n * (n - ) / ;
; i < n; ++i) {
scanf ("%d%d%d", &edge[i].s, &edge[i].e, &edge[i].cost);
par[edge[i].s] = edge[i].s;
par[edge[i].e] = edge[i].e;
}
sort (edge, edge + n, cmp);
; i < n; ++i) {
if (Find (edge[i].s) != Find (edge[i].e)) {
//cout << edge[i].s << ' ' << edge[i].e << endl;
join (edge[i].s, edge[i].e);
ans += edge[i].cost;
}
}
cout << ans << endl;
}
;
}
Hdu - 1598 find the most comfortable road
并查集 + 枚举
先排序(从大到小,从小到大都行),再枚举所有的边,记录其中的最大最小值,更新答案。
/**
* Fuck you.
* I love you too.
*/
#include<bits/stdc++.h>
#define lson i<<2
#define rson i<<2|1
#define LS l,mid,lson
#define RS mid+1,r,rson
#define mem(a,x) memset(a,x,sizeof(a))
#define gcd(a,b) __gcd(a,b)
#define ll long long
#define ull unsigned long long
#define lowbit(x) (x&-x)
#define enld endl
#define mian main
#define itn int
#define prinft printf
const double PI = acos (-1.0);
const int INF = 0x3f3f3f3f;
;
;
;
;
using namespace std;
int n, m, q;
int Max, Min, ans;
int x, y;
int par[N];
struct ed {
int s, e, cost;
} edge[MAXN];
bool cmp (ed a, ed b) {
return a.cost < b.cost;
}
int Find (int a) {
return a == par[a] ? a : par[a] = Find (par[a]);
}
void join (int a, int b) {
par[Find (a)] = Find (b);
}
void init() {
; i < m+; ++i)
par[i] = i;
}
int main() {
while (~scanf ("%d%d", &n, &m)) {
mem (par, );
; i < m; i++) {
scanf ("%d%d%d", &edge[i].s, &edge[i].e, &edge[i].cost);
}
sort (edge, edge + m, cmp);
scanf ("%d", &q);
while (q--) {
scanf ("%d%d", &x, &y);
ans = INF;
; j < m; j++) {
init();
Min = INF, Max = ;
for (int i = j; i < m; i++) {
if (Find (edge[i].s) != Find (edge[i].e)) {
join (edge[i].s, edge[i].e);
Min = min (Min, edge[i].cost), Max = max (Max, edge[i].cost);
}
if (Find (x) == Find (y)) {
ans = min (ans, Max - Min);
break;
}
}
}
if (ans == INF)
cout << "-1" << endl;
else {
cout << ans << endl;
}
}
}
;
}
Kruskal 模板的更多相关文章
- Kruskal模板
Kruskal模板 struct Edge { int from,to,v; }edge[maxn*10]; int fa[maxn]; int n,m; int find(int x) { retu ...
- POJ 1287 Networking【kruskal模板题】
传送门:http://poj.org/problem?id=1287 题意:给出n个点 m条边 ,求最小生成树的权 思路:最小生树的模板题,直接跑一遍kruskal即可 代码: #include< ...
- 最小生成树kruskal模板
算法思路:每次选取权值最小的边,判断这两个点是否在同一个集合内,如果在则跳过,如果不在则加上这条边的权值 可以使用并查集储存结点,可以快速判断结点是否在同一集合内. #include<iostr ...
- 最小生成树prim和kruskal模板
prim: int cost[MAX_V][MAX_V]; //cost[u][v]表示边e=(u,v)的权值(不存在的情况下设为INF) int mincost[MAX_V]; //从集合X出发的每 ...
- HDU 2988 Dark roads(kruskal模板题)
Dark roads Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- 【还是畅通工程 HDU - 1233】【Kruskal模板题】
Kruskal算法讲解 该部分内容全部摘录自刘汝佳的<算法竞赛入门经典> Kruskal算法的第一步是给所有边按照从小到大的顺序排列. 这一步可以直接使用库函数 qsort或者sort. ...
- Prime算法 与 Kruskal算法求最小生成树模板
算法原理参考链接 ==> UESTC算法讲堂——最小生成树 关于两种算法的复杂度分析 ==> http://blog.csdn.net/haskei/article/details/531 ...
- 最小生成树(次小生成树)(最小生成树不唯一) 模板:Kruskal算法和 Prim算法
Kruskal模板:按照边权排序,开始从最小边生成树 #include<algorithm> #include<stdio.h> #include<string.h> ...
- 【次小生成树】【Kruskal】【prim】【转】
原博客出处:https://blog.csdn.net/yasola/article/details/74276255 通常次小生成树是使用Prim算法进行实现的,因为可以在Prim算法松弛的同时求得 ...
随机推荐
- H5 Day2 练习
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- javascript私有方法揭示为公有方法
揭示模式可用于将私有方法暴露为公共方法.当为了对象的运转而将所有功能放置在一个对象中以及想尽可能地保护该对象,这种揭示模式就非常有用. 板栗: var myarray; (function(){ va ...
- bash脚本:集群资源争夺战crazy-killer
背景 公司的集群很多人一起用,有时候就难免资源紧张,某次需要用的时候没资源等了半天还是没资源,再等半天还是没资源,于是就写了个脚本泄愤,建议看到的人拷走放在自己公司集群上长期运行 :) 实现 此脚本运 ...
- Debian安装Nvidia最简单方法
电脑配置: Dell本本 i7+gtx1050+8g 安装bumblebee: sudo apt install bumblebee-nvidia primus 以上会自动安装nvidia驱动. bu ...
- 搜索引擎ElasticSearchV5.4.2系列三之ES使用
相关博文: 搜索引擎ElasticSearchV5.4.2系列一之ES介绍 搜索引擎ElasticSearchV5.4.2系列二之ElasticSearchV5.4.2+kibanaV5.4.2+x- ...
- 【前端开发】移动端适配方案js,rem单位转换,640设计稿20px=1rem
! function() { var style = document.createElement("STYLE"), docEl = document.documentEleme ...
- CF1063A 【Oh Those Palindromes】
考虑在一个部分串中加入字符使得最终构造的串回文子串最多的方案 考虑简单情况,对于只含一种元素的串,我们要插入其他元素 记原有元素为$a$,新加元素为$b$ 考虑$b$的最优插入位置 原串$aaaa.. ...
- windows 2008 启用.NET Framework 3.5
Win2008下已经集成了.NET 3.5.1 framework,需要在管理界面打开! 方法和步骤是: 服务器管理器 -> 功能 -> 添加功能 然后在“选择功能”界面勾选“.NET F ...
- Sqlserver中PIVOT行转列透视操作
创建表: IF OBJECT_ID('T040_PRODUCT_SALES') IS NOT NULL DROP TABLE T040_PRODUCT_SALES create table T040_ ...
- SendMessage原理初探
今天跟踪一下SendMessage的实现. 用向导先创建一个Windows application. 向导生成了一个简单的窗口,如下. 在File菜单添加SendMessage,顺便添加一个PostM ...