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 ...
随机推荐
- AspectFill VS. AspectFit
从去年10月进入公司,到现在差不多忙碌了3个月,期间几乎所有精力和时间都花在了公司的项目上,有很多工作学习的心得一直没有总结,趁周末无事就来使这写一写. 除了刚进公司的那一个月是做一些修修补补的工作, ...
- macosx安装MySQLdb
折腾了半天,记录一下. 先按照这个步骤安装mysql-python 如果python setup.py install 时候出现clang 错误,运行 python -E setup.py insta ...
- .NET Nancy 详解(四) Self Host
Self Host 使得Nancy 能够在任意application 中启动,无论是console 还是windows service.这期我们使用的版本是Nancy v0.4.0. Demo 首先看 ...
- 7-14 EXISTS子查询
EXISTS: 只注重于子查询是否有返回行,如果查有返回行返回结果为值,否则为假 并不使用子查询的结果,仅用于测试子查询是否有返回结果. 语法: IF EXISTS (子查询) BEGIN 语句块 E ...
- ImageSwitcher自定意效果+定时切换图片
Activity实现 1 import android.app.Activity; import android.os.Bundle; import android.view.MotionEvent; ...
- hdu 4035 2011成都赛区网络赛E 概率dp ****
太吊了,反正我不会 /* HDU 4035 dp求期望的题. 题意: 有n个房间,由n-1条隧道连通起来,实际上就形成了一棵树, 从结点1出发,开始走,在每个结点i都有3种可能: 1.被杀死,回到结点 ...
- Codeforces Round #174 (Div. 1) B. Cow Program(dp + 记忆化)
题目链接:http://codeforces.com/contest/283/problem/B 思路: dp[now][flag]表示现在在位置now,flag表示是接下来要做的步骤,然后根据题意记 ...
- Linux学习笔记(12)用户和用户组管理
越是对服务器安全性要求高的服务器,越需要建立合理的用户权限等级制度和服务器操作规范.在Linux中主要是通过用户配置文件来查看和修改用户信息. 1 用户信息文件 (1)用户信息文件/etc/passw ...
- AndroidTips:selector的disable状态为什么无效?
正确的姿势: <?xml version="1.0" encoding="utf-8"?> <selector xmlns:android=& ...
- JavaScript 之 iframe自适应问题---可以用来实现网页局部刷新
1.HTML <iframe src="index.html" id="iframepage" frameborder="0" scr ...