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的更多相关文章

  1. POJ 1258 + POJ 1287 【最小生成树裸题/矩阵建图】

    Farmer John has been elected mayor of his town! One of his campaign promises was to bring internet c ...

  2. 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 ...

  3. 最小生成树算法总结(Kruskal,Prim)

    今天复习最小生成树算法. 最小生成树指的是在一个图中选择n-1条边将所有n个顶点连起来,且n-1条边的权值之和最小.形象一点说就是找出一条路线遍历完所有点,不能形成回路且总路程最短. Kurskal算 ...

  4. 最小生成树模板【kruskal & prim】

    CDOJ 1966 Kruskal 解法 时间复杂度O(mlogm) m为边数,这里主要是边排序占时间,后面并查集还好 #include <cstdio> #include <cst ...

  5. BZOJ 1083 [SCOI2005]繁忙的都市 (最小生成树裸题无重边) 超简单写法!!

    Description 城市C是一个非常繁忙的大都市,城市中的道路十分的拥挤,于是市长决定对其中的道路进行改造.城市C的道路是这样分布的:城市中有n个交叉路口,有些交叉路口之间有道路相连,两个交叉路口 ...

  6. BZOJ 1083: [SCOI2005]繁忙的都市【Kruscal最小生成树裸题】

    1083: [SCOI2005]繁忙的都市 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2925  Solved: 1927[Submit][Sta ...

  7. hdu 1102(最小生成树)

    Constructing Roads Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  8. HDU 1233 最小生成树模板题,练练模板

    还是畅通工程 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  9. POJ 1287 Networking(最小生成树裸题有重边)

    Description You are assigned to design network connections between certain points in a wide area. Yo ...

随机推荐

  1. 如何安装sublime text2以及它的插件?

    下载Sublime Text2的安装包,安装,安装后打开的界面如图   下面我们来给他安装插件,首先安装packagecontrol,打开菜单栏中的View-->show console   在 ...

  2. 一种快速刷新richedit中内嵌动画的方法的实现

    在IM中使用动画表情是一种非常有趣的方式,然而选择一种合适的方式来实现却并不容易. 一般来说,除了自己去实现一个富文本控件,目前主要的解决方案有3种: 1.使用浏览器做容器. 2.使用QT提供的Ric ...

  3. C# 编码转换 UTF8转GB2312 GB2312转UTF8

    /// <summary> /// GB2312转换成UTF8 /// </summary> /// <param name="text">&l ...

  4. loj 1038(dp求期望)

    题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=25915 题意:求一个数不断地除以他的因子,直到变成1的时候 除的次 ...

  5. merge布局

    当LayoutInflater遇到这个标签时,它会跳过它,并将<merge />内的元素添加到<merge />的父元素里.迷惑了吗?让我们用<merge />来替 ...

  6. Linux学习笔记(23) Linux备份

    1. 备份概述 Linux系统需要备份的数据有/root,/home,/var/spool/mail,/etc及日志等其他目录. 安装服务的数据需要备份,如apache需要备份的数据有配置文件.网页主 ...

  7. 使用Eclipse将Web项目打Jar包方法

    1.对下载.安装和运行Eclipse,就不再说了: 2.找到待打包项目: 3.右键,Export-->Export: 4.选择,Jar: 5.按如图操作: 6.完成后:

  8. SpringHttpInvoker解析3-客户端实现

    主要的配置文件 <bean id="httpInvokerUserService" class="org.springframework.remoting.http ...

  9. DSP using MATLAB示例Example3.16

    代码: b = [0.0181, 0.0543, 0.0543, 0.0181]; % filter coefficient array b a = [1.0000, -1.7600, 1.1829, ...

  10. js:方法1. 数组

    Array.every() array.every(f); array.every(f, o); f(array[i], i, array) [1,2,3].every(function(x) { r ...