HDU 1102 最小生成树裸题,kruskal,prim
1、HDU 1102 Constructing Roads 最小生成树
2、总结:
题意:修路,裸题
(1)kruskal
//kruskal
#include<iostream>
#include<cstring>
#include<cmath>
#include<queue>
#include<algorithm>
#include<cstdio>
#define max(a,b) a>b?a:b
using namespace std;
#define LL long long
#define INF 0x3f3f3f3f
const int N=; int n,k;
int father[N]; struct Eage
{
int st,en,val;
}eage[N*(N+)/]; bool cmp(Eage a,Eage b)
{
return a.val<b.val;
} int findn(int x) //即并查集的查找
{
int t=x;
while(x!=father[x]){
x=father[x];
}
int p;
while(t!=x){
p=t;
t=father[t];
father[p]=x;
}
return x;
} int kruskal()
{
int sum=;
sort(eage,eage+k,cmp);
for(int i=;i<k;i++){
int x=findn(eage[i].st);
int y=findn(eage[i].en);
if(x!=y){
sum+=eage[i].val;
x=findn(x);
y=findn(y);
father[x]=y;
}
}
return sum;
} int main()
{
while(scanf("%d",&n)!=EOF)
{
int m;
k=;
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
scanf("%d",&m);
if(i<j){
eage[k].st=i; //st边起点,en边终点,k为边的条数
eage[k].en=j;
eage[k++].val=m;
}
}
} for(int i=;i<=n;i++){
father[i]=i;
}
int q,a,b;
scanf("%d",&q);
while(q--){
scanf("%d%d",&a,&b);
a=findn(a);
b=findn(b);
father[a]=findn(b); //把a与b连通
} int ans=kruskal();
printf("%d\n",ans);
} return ;
}
(2)prim
//prim
#include<iostream>
#include<cstring>
#include<cmath>
#include<queue>
#include<algorithm>
#include<cstdio>
#define max(a,b) a>b?a:b
using namespace std;
#define LL long long
#define INF 0x3f3f3f3f
const int N=; int n;
int mapn[N][N];
int visit[N],dis[N]; //dis存储每个点到所选结点的最短距离 int prim()
{
int sum=;
memset(visit,,sizeof(visit));
visit[]=;
for(int i=;i<=n;i++){ //先选第一个结点
dis[i]=mapn[][i];
}
for(int i=;i<n;i++) //注,<不是<=
{
int next,minn=INF;
for(int j=;j<=n;j++){ //找到下一个最近的结点
if(!visit[j]&&minn>dis[j]){
next=j;
minn=dis[j];
}
}
sum+=minn;
visit[next]=; for(int j=;j<=n;j++){ //更新dis
if(!visit[j]&&dis[j]>mapn[next][j]){
dis[j]=mapn[next][j];
}
}
}
return sum;
} int main()
{
int q,a,b;
while(scanf("%d",&n)!=EOF)
{
memset(mapn,INF,sizeof(mapn));
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
scanf("%d",&mapn[i][j]);
}
} scanf("%d",&q);
while(q--){
scanf("%d%d",&a,&b);
mapn[a][b]=mapn[b][a]=;
} int ans=prim();
printf("%d\n",ans);
} return ;
}
HDU 1102 最小生成树裸题,kruskal,prim的更多相关文章
- POJ 1258 + POJ 1287 【最小生成树裸题/矩阵建图】
Farmer John has been elected mayor of his town! One of his campaign promises was to bring internet c ...
- poj 1251 poj 1258 hdu 1863 poj 1287 poj 2421 hdu 1233 最小生成树模板题
poj 1251 && hdu 1301 Sample Input 9 //n 结点数A 2 B 12 I 25B 3 C 10 H 40 I 8C 2 D 18 G 55D 1 E ...
- 最小生成树算法总结(Kruskal,Prim)
今天复习最小生成树算法. 最小生成树指的是在一个图中选择n-1条边将所有n个顶点连起来,且n-1条边的权值之和最小.形象一点说就是找出一条路线遍历完所有点,不能形成回路且总路程最短. Kurskal算 ...
- 最小生成树模板【kruskal & prim】
CDOJ 1966 Kruskal 解法 时间复杂度O(mlogm) m为边数,这里主要是边排序占时间,后面并查集还好 #include <cstdio> #include <cst ...
- BZOJ 1083 [SCOI2005]繁忙的都市 (最小生成树裸题无重边) 超简单写法!!
Description 城市C是一个非常繁忙的大都市,城市中的道路十分的拥挤,于是市长决定对其中的道路进行改造.城市C的道路是这样分布的:城市中有n个交叉路口,有些交叉路口之间有道路相连,两个交叉路口 ...
- BZOJ 1083: [SCOI2005]繁忙的都市【Kruscal最小生成树裸题】
1083: [SCOI2005]繁忙的都市 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2925 Solved: 1927[Submit][Sta ...
- hdu 1102(最小生成树)
Constructing Roads Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- HDU 1233 最小生成树模板题,练练模板
还是畅通工程 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
- POJ 1287 Networking(最小生成树裸题有重边)
Description You are assigned to design network connections between certain points in a wide area. Yo ...
随机推荐
- Sql Server 索引之唯一索引和筛选索引
唯一索引(UNIQUE INDEX) 当主键创建时如果不设置为聚集索引,那么就一定是唯一的非聚集索引.实际上,唯一索引,故名思议就是它要求该列上的值是唯一的.唯一索引能够保证索引键中不包含重复的值, ...
- C# 创建Windows Service
当我们需要一个程序长期运行,但是不需要界面显示时可以考虑使用Windows Service来实现.这篇博客将简单介绍一下如何创建一个Windows Service,安装/卸载Windows Servi ...
- HR外包系统 - 客户员工 发薪需求/个税需求 设置
最好,客户公司层面进行设置,如果单一情况,只需要设置公司,如果不是单一情况,设置员工, 另外员工只能从公司设置好的地方选择过来. 增强系统简便设置和设置的灵活性.
- 思想&观点&人生
思想: 思想的直接表现往往是对事物的观点,观点越多并且越接近本质,表示思想越丰富和深刻 观点不是事实 观点是基于事实之上的一种系统性的判断和理解框架,事实是观点的基础 观点不一定正确 观点组成: 事实 ...
- 6个值得推荐的Android开源框架简介(转)
虽然我们在做app的时候并不一定用到框架,但是一些好框架的思想是非常有学习价值的 1.volley 项目地址 https://github.com/smanikandan14/Volley-demo ...
- 【项目经验】EasyUI Tree
ITOO5.0开始了,我参加了伟大的基础系统,从整体上来说,基础系统有三个职能: 1.自己的核心职能--选课(公共选修课,专业选修课),课表: 2.为其他系统提供真实数据: 3.维护信息 而近两三天, ...
- 【转】Kylin的Hierarchies,Derived维度方面配置优化
http://blog.csdn.net/jiangshouzhuang/article/details/51286150 Hierarchies: 理论上对于N维度,我们可以进行2的N次方的维度组合 ...
- DataTables - 问题集
1.增加额外搜索条件 var reqData = {}; var extraSearch = []; var oTable = $('table selector').dataTable({ 'aja ...
- Uva10635 LCS
题目链接:http://vjudge.net/contest/137498#problem/G 题意:有两个长度为p+1和q+1的序列,每个序列的中的各个元素互不相同,且都是1~n^2之间的整.两个序 ...
- for的冒泡排序练习题
这是一个冒泡排序的方法,请汲取其中的思想.有一组数: 1,2,3,4,5,6请将这组数用降序排列.我们可以将数组里面的数两两相比,如果第二个数比第一个数大,那么将第二个数值与第一个数值交换,然后让其循 ...