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 ...
随机推荐
- 【noi 2.6_7113】Charm Bracelet(DP)
题意:N个饰物,有重量和渴望程度.问在M的重量限制内能达到的最大的渴望度. 解法:经典的01问题,但有一个小技巧值得记住:用if比较大小比调用max函数快了不少,这题有100ms左右. 1 #incl ...
- Codeforces Round #544 (Div. 3) E. K Balanced Teams (DP)
题意:有\(n\)个人,每个人的能力值是\(a_i\),现在你想将这些人分成\(k\)组(没必要全选),但是每组中最高水平和最低水平的人的能力差值必须\(\le 5\),问最多能选多少人. 题解:想了 ...
- 动态链接库(DLL)的创建和使用
最近想做个记录日志的C++库,方便后续使用.想着使用动态库,正好没用过,学习下.概念这里不赘述.学习过程中碰到的几点,记录下来.学习是个渐进的过程,本文也是一个逐渐完善的过程. 一.Static Li ...
- LVS-DR 模式
SNAT(Source Network Address Translation)源地址转换,类似家里路由器设置,内网地址向外访问时,发起访问的内网ip地址转换为指定的 IP 地址 DNAT(Desti ...
- ubuntu 16.04 i386 安装 ruby + bundler + rails ; 搭建简单的网站bitbar
参考 http://gorails.com/setup/ubuntu/16.04 概述 Project 2 主要探究对web的攻击,本次试验共有6个部分. Project 2中攻击的是一个提供电子货币 ...
- 信号量解决写者优先&读者优先&公平竞争(reader writer)
先说问题: 这里的rand都是伪随机.解决也很简单,srand即可.内容懒得改了~~ 描述及思路: 代码: 运行结果: 读者优先: 效果 ...
- 51nod-1065 最小正子段和 【贪心 + 思维】
N个整数组成的序列a[1],a[2],a[3],-,a[n],从中选出一个子序列(a[i],a[i+1],-a[j]),使这个子序列的和>0,并且这个和是所有和>0的子序列中最小的. 例如 ...
- [转]论基于DSSA的软件架构设计与应用
[摘要] 去年三月份,我所在的公司启动国网电力用户用电信息采集系统项目,我被任命为项目负责人.国网电力用户用电信息采集系统是国家电网公司坚强智能电网建设的一部分.由于公司之前为南网(主要是广东省) ...
- Android低功耗蓝牙(蓝牙4.0)——BLE开发(上)
段时间,公司项目用到了手机APP和蓝牙设备的通讯开发,这里也正好对低功耗蓝牙(蓝牙4.0及以后标准)的开发,做一个总结. 蓝牙技术联盟在2010年6月30号公布了蓝牙4.0标准,4.0标准在蓝牙3.0 ...
- stackoverflow & xgqfrms
stackoverflow & xgqfrms stackoverflow https://stackoverflow.com/users/5934465/xgqfrms https://st ...