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语句的性能和改进途径
用EXPLAIN吧... EXPLAIN , , , ) \G;
- 一次Promise 实践:异步任务的分组调度
起因是在工作中遇到一个问题,可以用一个二维数组简单描述: [[1,2,3],[4,5,6],[7,8,9]] 这里每个数字都代表“一个异步计算任务”, 每个子数组把1个或多个计算任务划分成组,要求是: ...
- GENERATED_UCLASS_BODY 和 GENERATED_BODY 区别
the GENERATED_BODY() macro allows the class to build without having a constructor defined. If you ne ...
- RSA 加解密算法
与DES不同,RSA算法中,每个通信主体都有两个钥匙,一个公钥一个私钥. 就是有2把钥匙1.使用publicKey可以对数据进行加密2.使用Key才能对数据进行解密单方向传输用公钥加密的数据,只有私钥 ...
- 获取当前IP地址,跳转到对应城市网站。
index.php文件 1,通过获取当前IP地址, 2,调用新浪AIP,获取到当前城市. 3,将中文转换为拼音后跳转. <?php include './pinyin.php'; //获取当前i ...
- 第七篇:创建一个SOUI的Hello World
从0开始一个SOUI项目 1.环境配置 SOUI项目本质是一个基于Win32窗口的应用程序.因此首先我们可以从Win32窗口应用程序向导创建一个简单的Win32项目. 并在第3页选择“Window应用 ...
- loj 1406(状态压缩)
题目链接:http://lightoj.com/volume_showproblem.php?problem=1406 思路:首先可以预处理出在每个顶点的状态的合法状态vis[u][state], 然 ...
- 【SQL Sever】实现SQL Sever的发布。订阅。 双机热备
实现SQL Sever的发布和订阅 最大的好处就是: 可以实现读写分离,增删改操作在主数据库服务器上进行,查询在备份数据库服务器上进行.一方面提高软件执行效率,另一方面也减轻主库压力. 本次实现发布 ...
- RecyclerView再封装
RecyclerView做为ListView的替代品,已经出了很久了,既然是替代品,那自然有些ListView没有的优点.比如说:可以随意切换list,grid,stagger.可以指定一个或多个it ...
- jQuery WipeTouch
有时,当你只想为触屏划动添加事件时,很多人可能会想到,Jquery mobile,但就这么个功能就把人家这么高大上的东西引用进来就有点大才小用了,WipeTouch是国外某程序员写的针对触屏划动的jq ...