最小生成树练习3(普里姆算法Prim)
风萧萧兮易水寒,壮士要去敲代码。本女子开学后再敲了。。
poj1258 Agri-Net(最小生成树)水题。
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int inf=0x3f3f3f3f;
const int N=;
int n,m;
int g[N][N],low[N];
void prim(int u0){
int i,j,mi,v,ans=;
for(i=;i<n;++i){
low[i]=g[u0][i];
}
low[u0]=-;
for(i=;i<n;++i){
mi=inf;
v=-;
for(j=;j<n;++j)
if(low[j]!=-&&low[j]<mi){
v=j; mi=low[j];
}
ans+=low[v];
low[v]=-;
for(j=;j<n;++j){
if(g[v][j]<low[j]){
low[j]=g[v][j];
}
}
}
printf("%d\n",ans);
}
int main(){
int t,i,j;
while(scanf("%d",&n)==){
memset(g,inf,sizeof(inf));
for(i=;i<n;++i)
for(j=;j<n;++j)
scanf("%d",&g[i][j]);
prim();
}
return ;
}
poj1751 Highways(最小生成树)水题。已修好的路赋值为0。不用sqrt计算距离,因为题目没要求。做完这题后把自学时的模板改了一点,因为一开始的模板太挫。。
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
const int inf=0x3f3f3f3f;
const int N=;
int n,m;
int g[N][N],low[N],near[N],x[N],y[N];
void prim(int u0){
int i,j,mi,v;
for(i=;i<=n;++i){
low[i]=g[u0][i];
near[i]=u0;
}
low[u0]=-;
for(i=;i<n;++i){
mi=inf;
v=-;
for(j=;j<=n;++j)
if(low[j]!=-&&low[j]<mi){
v=j; mi=low[j];
}
if(mi!=)printf("%d %d\n",near[v],v);
low[v]=-;
for(j=;j<=n;++j){
if(g[v][j]<low[j]){
low[j]=g[v][j];
near[j]=v;
}
}
}
}
int main(){
int t,i,j;
scanf("%d",&n);
memset(g,inf,sizeof(g));
for(i=;i<=n;++i) scanf("%d%d",&x[i],&y[i]);
for(i=;i<=n;++i){
for(j=i+;j<=n;++j){
g[i][j]=g[j][i]=(x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]);
}
}
scanf("%d",&m);
while(m--){
scanf("%d%d",&i,&j);
g[i][j]=g[j][i]=;
}
prim();
return ;
}
poj1789 Truck History(最小生成树)每种卡车类型都是由其他卡车类型派生出来,第一种除外。理解:顶点为卡车类型,边的权值为类型对(t0,d0)的距离(编码中不同字符的位置数目)。。看懂题看得头疼,其实不难做。
#include<cstdio>
#include<cstring>
using namespace std;
const int inf=0x3f3f3f3f;
const int N=;
int n;
char code[N][];
int g[N][N],low[N],a[N],ans;
void prim(int u0){
int i,j,mi,v;
ans=;
for(i=;i<n;++i){
low[i]=g[u0][i];
}
low[u0]=-;
for(i=;i<n;++i){
mi=inf;
v=-;
for(j=;j<n;++j)
if(low[j]!=-&&low[j]<mi){
v=j; mi=low[j];
}
ans+=low[v];
low[v]=-;
for(j=;j<n;++j){
if(g[v][j]<low[j])
low[j]=g[v][j];
}
}
printf("The highest possible quality is 1/%d.\n",ans);
}
int main(){
int i,j,k,d;
while(scanf("%d",&n),n){
memset(g,inf,sizeof(g));
for(i=;i<n;++i) scanf("%s",code[i]);
for(i=;i<n-;++i){
for(j=i+;j<n;++j){
d=;
for(k=;k<;++k)
d+=(code[i][k]!=code[j][k]);
g[i][j]=g[j][i]=d;
}
}
prim();
}
return ;
}
poj2349 Arctic Network(最小生成树)求出最小生成树,将边从大到小排序,前s-1条用s个卫星通信,第s大边即为答案。
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
const int inf=0x3f3f3f3f;
const int N=;
int n,s;
double g[N][N],low[N],d[N],x[N],y[N];
int cmp(int a,int b){
return a > b;
}
void prim(int u0){
int i,j,mi,v;
int cnt=;
for(i=;i<n;++i){
low[i]=g[u0][i];
}
low[u0]=-;
for(i=;i<n;++i){
mi=inf;
v=-;
for(j=;j<n;++j)
if(low[j]!=-&&low[j]<mi){
v=j; mi=low[j];
}
d[cnt++]=low[v];
low[v]=-;
for(j=;j<n;++j){
if(g[v][j]<low[j])
low[j]=g[v][j];
}
}
sort(d,d+cnt,cmp);
printf("%.2f\n",d[s-]);
}
int main(){
int t,i,j;
double d;
scanf("%d",&t);
while(t--){
memset(g,inf,sizeof(g));
scanf("%d%d",&s,&n);
for(i=;i<n;++i) scanf("%lf%lf",&x[i],&y[i]);
for(i=;i<n;++i){
for(j=i+;j<n;++j){
d=sqrt((x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]));
g[i][j]=g[j][i]=d;
}
}
prim();
}
return ;
}
poj3026 Borg Maze(最小生成树,bfs预处理)因为这题我几天没打码了,今天做出来感觉也不是很难。还是深感基础之弱内心痛苦。。对了,记得看discuss哦,如果你不想多挥霍青春的话。。。
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
const int inf=0x3f3f3f3f;
const int N=;
const int M=;
int x,y;
int n;
int dir[][]={,,,-,,,-,};
int g[M][M],low[M];
char mp[N][N];
int G[N][N];
int vd[N][N];
void bfs(int sx,int sy){
queue<pair<int,int> >q;
while(!q.empty())q.pop();
memset(vd,-,sizeof(vd));
vd[sx][sy]=;
q.push(make_pair(sx,sy));
while(!q.empty()){
pair<int,int>u=q.front(); q.pop();
if(G[u.first][u.second]>)
g[G[sx][sy]][G[u.first][u.second]]=vd[u.first][u.second];
for(int i=;i<;++i){
int xx=u.first+dir[i][];
int yy=u.second+dir[i][];
if(mp[xx][yy]=='#'||vd[xx][yy]!=-)continue;
vd[xx][yy]=vd[u.first][u.second]+;
q.push(make_pair(xx,yy));
}
}
}
void prim(int u0){
int i,j,mi,v,ans=;
for(i=;i<n;++i) low[i]=g[u0][i];
low[u0]=-;
for(i=;i<n-;++i){
mi=inf;
v=-;
for(j=;j<n;++j)
if(low[j]!=-&&low[j]<mi){
v=j; mi=low[j];
}
ans+=low[v];
low[v]=-;
for(j=;j<n;++j){
if(g[v][j]<low[j]){
low[j]=g[v][j];
}
}
}
printf("%d\n",ans);
}
int main(){
int t,i,j;
scanf("%d",&t);
while(t--){
scanf("%d%d",&x,&y);
gets(mp[]);
for(i=;i<y;++i) gets(mp[i]);
n=;
for(i=;i<y;++i){
for(j=;j<x;++j){
if(mp[i][j]=='A'||mp[i][j]=='S')
G[i][j]=n++;
else G[i][j]=-;
}
}
for(i=;i<y;++i)
for(j=;j<x;++j)
if(G[i][j]>) bfs(i,j);
prim();
}
return ;
}
最小生成树练习3(普里姆算法Prim)的更多相关文章
- hdu 1233:还是畅通工程(数据结构,图,最小生成树,普里姆(Prim)算法)
还是畅通工程 Time Limit : 4000/2000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total Submis ...
- 最小生成树---普里姆算法(Prim算法)和克鲁斯卡尔算法(Kruskal算法)
普里姆算法(Prim算法) #include<bits/stdc++.h> using namespace std; #define MAXVEX 100 #define INF 6553 ...
- 查找最小生成树:普里姆算法算法(Prim)算法
一.算法介绍 普里姆算法(Prim's algorithm),图论中的一种算法,可在加权连通图里搜索最小生成树.意即由此算法搜索到的边子集所构成的树中,不但包括了连通图里的所有顶点,且其所有边的权值之 ...
- ACM第四站————最小生成树(普里姆算法)
对于一个带权的无向连通图,其每个生成树所有边上的权值之和可能不同,我们把所有边上权值之和最小的生成树称为图的最小生成树. 普里姆算法是以其中某一顶点为起点,逐步寻找各个顶点上最小权值的边来构建最小生成 ...
- 图->连通性->最小生成树(普里姆算法)
文字描述 用连通网来表示n个城市及n个城市间可能设置的通信线路,其中网的顶点表示城市,边表示两城市之间的线路,赋于边的权值表示相应的代价.对于n个定点的连通网可以建立许多不同的生成树,每一棵生成树都可 ...
- 普里姆算法(Prim)
概览 普里姆算法(Prim算法),图论中的一种算法,可在加权连通图(带权图)里搜索最小生成树.即此算法搜索到的边(Edge)子集所构成的树中,不但包括了连通图里的所有顶点(Vertex)且其所有边的权 ...
- 普里姆(Prim)算法
概览 普里姆算法(Prim算法),图论中的一种算法,可在加权连通图(即"带权图")里搜索最小生成树.即此算法搜索到的边(Edge)子集所构成的树中,不但包括了连通图里的所有顶点(V ...
- HDU 1879 继续畅通工程 (Prim(普里姆算法)+Kruskal(克鲁斯卡尔))
继续畅通工程 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Sub ...
- Prim算法(普里姆算法)
描述: 一个连通图的生成树是指一个极小连通子图,它含有图中的全部顶点,但只有足以构成一棵树的 n-1 条边.我们把构造连通网的最小代价生成树成为最小生成树.而Prim算法就是构造最小生成树的一种算法. ...
随机推荐
- Struts2-S2-032远程命令执行EXP
看到网上好多写的EXP有后门啊 还是自己写个吧! 工具下载:链接: http://pan.baidu.com/s/1miRbi2k 密码: fzfv
- 【VB6笔记-02】从Command中获取链接参数
Public Sub GetParameters() Dim Para As String Para = Command$() gstrUserID = GetCommandPara(Para, ) ...
- poj 2398 (叉积+二分)
http://poj.org/problem?id=2398 Toy Storage Time Limit: 1000MS Memory Limit: 65536K Total Submissio ...
- Android中四种OnClick事件的写法
package com.example.dailphone; import android.support.v7.app.ActionBarActivity; import android.suppo ...
- Web Service 接口实现大量数据传输的解决方案
1,流程图 2,流程说明:线程1开始请求接口获取1W条数据,当数据成功获取后,接口是闲置的,这时我们开始线程2获取数据,同时线程1继续执行获取数据的后续工作,如果转换数据,这里我用的办法是,使用预先定 ...
- [转载] HTTP请求的TCP瓶颈分析
原文: http://bhsc881114.github.io/2015/06/23/HTTP%E8%AF%B7%E6%B1%82%E7%9A%84TCP%E7%93%B6%E9%A2%88%E5%8 ...
- 学习日记day8:移动端页面流程优化
一:切图 1:切那些(移动端能不用图片就不用图片:logo单独切因为要带链接) 2:普通切(快捷键:复制到新图层 选中 复制 新建 粘贴 保存) 3:类似切 (选中多个图层 矩形框多选 选择工 ...
- bootstrap 手风琴效果
<!DOCTYPE HTML> <html><head><meta charset="utf-8"><title>按钮插 ...
- OpenGL的几何变换3之内观察全景图
继续上一篇文章的例子:OpenGL的几何变换2之内观察立方体 上一篇是通过绘图方式得到的立方体,没有贴图,这次加上纹理贴图. 通过纹理贴图有两种方案: 1.图片分割化,即是把一张完整的全景图片(就是支 ...
- 最大堆的插入/删除/调整/排序操作(图解+程序)(JAVA)
堆有最大堆和最小堆之分,最大堆就是每个节点的值都>=其左右孩子(如果有的话)值的完全二叉树.最小堆便是每个节点的值都<=其左右孩子值的完全二叉树. 设有n个元素的序列{k1,k2,..., ...