POJ-3026(图上的最小生成树+prim算法+gets函数使用)
Borg Maze
POJ-3026
- 一开始看到这题是没有思路的,看了题解才知道和最小生成树有关系。
- 题目的意思是每次走到一个A或者S就可以分为多个部分继续进行搜索。这里就可以看出是从该点分出去的不同路径。
- 所以首先需要使用bfs求出每对顶点的最短路来,但是在这个过程中,我出了个bug,导致调试半天,就是那里bfs上下左右走的时候的x,y都用的原来的。
- 最小生成树就是使用prim算法,该算法和dijikstra算法特别像,唯一有区别的就是mincost函数的定义。
#include<iostream>
#include<cmath>
#include<cstring>
#include<string>
#include<cstdio>
#include<algorithm>
#include<vector>
#include<queue>
using namespace std;
const int INF=0X3F3F3F3F;
int m,n;
char map[55][55];
int cnt[55][55];
bool vis[55][55];
int ma[202][202];
int dir[4][2]={{-1,0},{0,-1},{1,0},{0,1}};
int total;
struct node{
int x;
int y;
int dis;
};
bool in(int x,int y){
return x>=1&&x<=n&&y>=1&&y<=m;
}
void bfs(int x,int y){
memset(vis,0,sizeof(vis));
queue<node> q;
q.push(node{x,y,0});
vis[x][y]=1;
while(!q.empty()){
node temp=q.front();
q.pop();
if(cnt[temp.x][temp.y]>0){//该结点是A或者S
ma[cnt[x][y]][cnt[temp.x][temp.y]]=temp.dis;
}
for(int i=0;i<4;i++){
int tx=dir[i][0]+temp.x;
int ty=dir[i][1]+temp.y;
// cout<<tx<<" "<<ty<<endl;
if(in(tx,ty)&&!vis[tx][ty]&&map[tx][ty]!='#'){
//cout<<tx<<" "<<ty<<" "<<map[tx][ty]<<endl;
vis[tx][ty]=1;
q.push(node{tx,ty,temp.dis+1});
//cout<<tx<<" "<<ty<<endl;
}
}
}
//cout<<endl;
}
bool viss[202];
int mincost[202];
int prim(int s){
memset(viss,0,sizeof(viss));
memset(mincost,INF,sizeof(mincost));
mincost[s]=0;
int ans=0;
for(int i=1;i<=total;i++){
int v=-1;
int mins=INF;
for(int j=1;j<=total;j++){
if(!viss[j]&&mincost[j]<mins){
mins=mincost[j];
v=j;
}
}
if(v==-1)
break;
viss[v]=1;
ans+=mins;//mincost[v]
for(int j=1;j<=total;j++){
mincost[j]=min(mincost[j],ma[v][j]);
}
}
return ans;
}
int main(){
int t;
cin>>t;
while(t--){
cin>>m>>n;
total=0;
memset(cnt,0,sizeof(cnt));
gets(map[0]);
for(int i=1;i<=n;i++){
gets(map[i]+1);//这里从第i行第2个字符开始读入
}
for(int i=1;i<=n;i++){
//cout<<map[i]<<endl;
for(int j=1;j<=m;j++){
if(map[i][j]=='S'||map[i][j]=='A'){
cnt[i][j]=++total;
//cout<<map[i][j]<<" ";
}
//cout<<map[i][j]<<" ";
}
//cout<<endl;
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(cnt[i][j]>0){
bfs(i,j);
}
}
}
// for(int i=1;i<=total;i++){
// for(int j=1;j<=total;j++){
// cout<<ma[i][j]<<" ";
// }
// cout<<endl;
// }
cout<<prim(1)<<endl;
}
return 0;
}
POJ-3026(图上的最小生成树+prim算法+gets函数使用)的更多相关文章
- 数据结构代码整理(线性表,栈,队列,串,二叉树,图的建立和遍历stl,最小生成树prim算法)。。持续更新中。。。
//归并排序递归方法实现 #include <iostream> #include <cstdio> using namespace std; #define maxn 100 ...
- 最小生成树Prim算法(邻接矩阵和邻接表)
最小生成树,普利姆算法. 简述算法: 先初始化一棵只有一个顶点的树,以这一顶点开始,找到它的最小权值,将这条边上的令一个顶点添加到树中 再从这棵树中的所有顶点中找到一个最小权值(而且权值的另一顶点不属 ...
- 最小生成树 Prim算法 Kruskal算法实现
最小生成树定义 最小生成树是一副连通加权无向图中一棵权值最小的生成树. 在一给定的无向图 G = (V, E) 中,(u, v) 代表连接顶点 u 与顶点 v 的边(即,而 w(u, v) 代表此边的 ...
- 图论算法(五)最小生成树Prim算法
最小生成树\(Prim\)算法 我们通常求最小生成树有两种常见的算法--\(Prim\)和\(Kruskal\)算法,今天先总结最小生成树概念和比较简单的\(Prim\)算法 Part 1:最小生成树 ...
- Highways POJ-1751 最小生成树 Prim算法
Highways POJ-1751 最小生成树 Prim算法 题意 有一个N个城市M条路的无向图,给你N个城市的坐标,然后现在该无向图已经有M条边了,问你还需要添加总长为多少的边能使得该无向图连通.输 ...
- SWUST OJ 1075 求最小生成树(Prim算法)
求最小生成树(Prim算法) 我对提示代码做了简要分析,提示代码大致写了以下几个内容 给了几个基础的工具,邻接表记录图的一个的结构体,记录Prim算法中最近的边的结构体,记录目标边的结构体(始末点,值 ...
- 最小生成树,Prim算法与Kruskal算法,408方向,思路与实现分析
最小生成树,Prim算法与Kruskal算法,408方向,思路与实现分析 最小生成树,老生常谈了,生活中也总会有各种各样的问题,在这里,我来带你一起分析一下这个算法的思路与实现的方式吧~~ 在考研中呢 ...
- 最小生成树—prim算法
最小生成树prim算法实现 所谓生成树,就是n个点之间连成n-1条边的图形.而最小生成树,就是权值(两点间直线的值)之和的最小值. 首先,要用二维数组记录点和权值.如上图所示无向图: int map[ ...
- CDOJ 1146 A - 秋实大哥与连锁快餐店 最小生成树 Prim算法 稠密图
题目链接 A - 秋实大哥与连锁快餐店 Time Limit:3000MS Memory Limit:65535KB 64bit IO Format:%lld & %llu S ...
随机推荐
- Berry Jam (前缀和)cf教育场
距离上一篇博客又2个月了 寻思着该除除草了 教育场是真的好难 可能是因为我还是只菜鸡 哭唧唧 先说下题意:有2*n罐果酱,草莓和蓝莓,梯子在中间从梯子那开始往两边吃(可以一会左一会右),问最少吃多少果 ...
- 【noi 2.7_413】Calling Extraterrestrial Intelligence Again(算法效率--线性筛素数+二分+测时)
题意:给3个数M,A,B,求两个质数P,Q.使其满足P*Q<=M且A/B<=P/Q<=1,并使P*Q最大.输入若干行以0,0,0结尾. 解法:先线性筛出素数表,再枚举出P,二分出对应 ...
- codeforces 292E. Copying Data
We often have to copy large volumes of information. Such operation can take up many computer resourc ...
- Educational Codeforces Round 88 (Rated for Div. 2) E、Modular Stability 逆元+思维
题目链接:E.Modular Stability 题意: 给你一个n数,一个k,在1,2,3...n里挑选k个数,使得对于任意非负整数x,对于这k个数的任何排列顺序,然后用x对这个排列一次取模,如果最 ...
- Educational Codeforces Round 88 (Rated for Div. 2) B、New Theatre Square C、Mixing Water
题目链接:B.New Theatre Square 题意: 你要把所有"." 都变成"*",你可以有两个选择,第一种就是一次铺一个方块(1*1),第二种就是同一 ...
- Codeforces Round #481 (Div. 3) C. Letters (模拟,二分)
题意:有个\(n\)个公寓,每个公寓\(a_{i}\)代表着编号为\(1-a_{i}\)个房间,给你房间号,问它在第几栋公寓的第几个房间. 题解:对每个公寓的房间号记一个前缀和,二分查找属于第几个公寓 ...
- Linux-进程管理命令
目录 进程管理命令-ps(静态) 进程管理命令-top(动态) 什么是中断 管理进程状态 kill命令 killall命令 pkill命令 pidof 和 pgrep 补充 关于优先级PR和NI 后台 ...
- mssql 2005安装
SQL Server 2005详细安装过程及配置 说明:个人感觉SQL Server 2005是目前所有的SQL Server版本当中最好用的一个版本了,原因就是这个版本比起其它版本来说要安装简单 ...
- 恕我直言!!!对于Maven,菜鸟玩dependency,神仙玩plugin
打包是一项神圣.而庄严的工作.package意味着我们离生产已经非常近了.它会把我们之前的大量工作浓缩成为一个.或者多个文件.接下来,运维的同学就可以拿着这些个打包文件在生产上纵横四海了. 这么一项庄 ...
- PWA & Service Workers 版本更新 bug
PWA & Service Workers 版本更新 bug PWA & Service Worker https://developer.mozilla.org/zh-CN/docs ...