我个人比较喜欢Kruskal算法,所以就把这个方法写了一下,但过不了洛谷,70分。

思路是先全读入,再排序,一条一条加边。运用并查集。

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
struct s{
int h;
int t;
int w;
};
int fa[];
bool cmp(s a,s b)
{
return a.w < b.w;
}
int find(int a)
{
if(fa[a] != a) //不是while
fa[a] = find(fa[a]);
return fa[a];
}
void un(int a,int b)
{
a = find(a);
b = find(b);
if(a != b)
fa[b] = a;
}
bool judge(int a,int b)
{
a = find(a);
b = find(b);
if(a != b)
return false;
else return true;
}
s side[];
int m,n,k,tot = ,num = ;
int main()
{
cin>>n>>k;
for(int i = ;i <= n;i++)
{
fa[i] = i;
}
for(int i = ;i <= k;i++)
{
cin>>side[i].h>>side[i].t>>side[i].w;
//tot += side[i].w;
}
sort(side + ,side + k + ,cmp);
tot = ;
for(int i = ;i <= k;i++)
{
if(judge(side[i].h,side[i].t) == false)
{
un(side[i].h,side[i].t);
tot += side[i].w;
num++;
}
if(num == n)
break;
}
cout<<tot<<endl;
return ;
}
/*
5 5
1 2 8
1 3 1
1 5 3
2 4 5
3 4 2
*/

再加一个并查集的板子,日后备用。

#include<iostream>
using namespace std;
int fa[],m,n,x,y,z;
int find(int a)
{
if(fa[a] != a)
fa[a] = find(fa[a]);
return fa[a];
}
bool judge(int a,int b)
{
a = find(a);
b = find(b);
if(a != b)
return false;
else
return true;
}
void un(int a,int b)
{
a = find(a);
b = find(b);
if(a != b)
fa[b] = a;
}
int main()
{
cin>>m>>n;
for(int i = ;i < m;i++)
fa[i] = i;
for(int i = ;i <n;i++)
{
cin>>x>>y>>z;
if(x == )
{
if(judge(y,z) == false)
un(y,z);
}
else
{
if(judge(y,z) == true)
cout<<"Yeah"<<endl;
else
cout<<"No,opps"<<endl;
}
}
return ;
}

复习--最小生成树&&并查集的更多相关文章

  1. UVA 1395 苗条的生成树(最小生成树+并查集)

    苗条的生成树 紫书P358 这题最后坑了我20分钟,怎么想都对了啊,为什么就wa了呢,最后才发现,是并查集的编号搞错了. 题目编号从1开始,我并查集编号从0开始 = = 图论这种题真的要记住啊!!题目 ...

  2. CSP 201703-4 地铁修建【最小生成树+并查集】

    问题描述 试题编号: 201703-4 试题名称: 地铁修建 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 A市有n个交通枢纽,其中1号和n号非常重要,为了加强运输能力,A市 ...

  3. 关于最小生成树(并查集)prime和kruskal

    适合对并查集有一定理解的人.  新手可能看不懂吧.... 并查集简单点说就是将相关的2个数字联系起来 比如 房子                      1   2    3   4  5   6 ...

  4. 【BZOJ4144】[AMPPZ2014]Petrol(最短路+最小生成树+并查集)

    Description 给定一个n个点.m条边的带权无向图,其中有s个点是加油站. 每辆车都有一个油量上限b,即每次行走距离不能超过b,但在加油站可以补满. q次询问,每次给出x,y,b,表示出发点是 ...

  5. bzoj 3559: [Ctsc2014]图的分割【最小生成树+并查集】

    读题两小时系列-- 在读懂题意之后,发现M(c)就是c这块最大权割边也就是的最小生成树的最大权边的权值,所以整个问题都可以在MST的过程中解决(M和c都是跟着并查集变的) 不过不是真的最小生成树,是合 ...

  6. Regional Changchun Online--Travel(最小生成树&& 并查集)

    Travel Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) Total S ...

  7. UOJ14 UER #1 DZY Loves Graph(最小生成树+并查集)

    显然可以用可持久化并查集实现.考虑更简单的做法.如果没有撤销操作,用带撤销并查集暴力模拟即可,复杂度显然可以均摊.加上撤销操作,删除操作的复杂度不再能均摊,但注意到我们在删除时就可以知道他会不会被撤销 ...

  8. (最小生成树 并查集)P1111 修复公路 洛谷

    题目背景 A地区在地震过后,连接所有村庄的公路都造成了损坏而无法通车.政府派人修复这些公路. 题目描述 给出A地区的村庄数N,和公路数M,公路是双向的.并告诉你每条公路的连着哪两个村庄,并告诉你什么时 ...

  9. Luogu P1195/P1892 口袋的天空/BOI团伙 【最小生成树/并查集】By cellur925

    其实这俩题挺水的,团伙拿下了一血,但是感觉还是写一下博客比较好x. 一.团伙 题目描述 1920年的芝加哥,出现了一群强盗.如果两个强盗遇上了,那么他们要么是朋友,要么是敌人.而且有一点是肯定的,就是 ...

随机推荐

  1. Json——Json与JS的区别

    JSON是JS的字面量的特殊表现形式,它使用文本表示 JS 对象信息,本质是字符串 var obj = {a: 'Hello', b: 'World'}; //这是一个对象,注意键名也是可以使用引号包 ...

  2. CSS——background

    背景经常用到以下属性: background-color: aliceblue; background-image: url('2017102601.png'); background-positio ...

  3. Centos 安装 Moosefs文件系统

    一.环境介绍Moosefs master:192.168.55.148Moosefs Metalogger:192.168.55.149Moosefs Chunk-01:192.168.55.150M ...

  4. c#仿照qq登录界面编辑框内容操作

    using System; using System.Drawing; using System.Windows.Forms; namespace 案例演示 { public partial clas ...

  5. eclipse版本和jdk的版本兼容问题

    eclipse也是有版本的,当版本过低时,无法兼容高版本的jdk 项目中用的是jdk1.8,但是低版本的eclipse只能选到jdk1.7,导致java文件在编译的过程中,不识别1.8版本jdk的语法 ...

  6. day07-列表类型/元组类型/字典类型/集合类型内置方法

    目录 列表类型内置方法 元组类型内置方法 字典类型内置方法 集合类型内置方法 列表类型内置方法 用来存多个元素,[]内用逗号隔开任意数据类型的元素 1. list()强制类型转换 print(list ...

  7. HDU 3152 Obstacle Course(优先队列,广搜)

    题目 用优先队列优化普通的广搜就可以过了. #include<stdio.h> #include<string.h> #include<algorithm> usi ...

  8. 00.pip安装包

    pip安装更换镜像源 pip install 包名 -i http://pypi.douban.com/simple/ --trusted-host pypi.douban.com pip导出和导入 ...

  9. PAT 1091. Acute Stroke (bfs)

    One important factor to identify acute stroke (急性脑卒中) is the volume of the stroke core. Given the re ...

  10. 198. House Robber(动态规划)

    You are a professional robber planning to rob houses along a street. Each house has a certain amount ...