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函数使用)的更多相关文章

  1. 数据结构代码整理(线性表,栈,队列,串,二叉树,图的建立和遍历stl,最小生成树prim算法)。。持续更新中。。。

    //归并排序递归方法实现 #include <iostream> #include <cstdio> using namespace std; #define maxn 100 ...

  2. 最小生成树Prim算法(邻接矩阵和邻接表)

    最小生成树,普利姆算法. 简述算法: 先初始化一棵只有一个顶点的树,以这一顶点开始,找到它的最小权值,将这条边上的令一个顶点添加到树中 再从这棵树中的所有顶点中找到一个最小权值(而且权值的另一顶点不属 ...

  3. 最小生成树 Prim算法 Kruskal算法实现

    最小生成树定义 最小生成树是一副连通加权无向图中一棵权值最小的生成树. 在一给定的无向图 G = (V, E) 中,(u, v) 代表连接顶点 u 与顶点 v 的边(即,而 w(u, v) 代表此边的 ...

  4. 图论算法(五)最小生成树Prim算法

    最小生成树\(Prim\)算法 我们通常求最小生成树有两种常见的算法--\(Prim\)和\(Kruskal\)算法,今天先总结最小生成树概念和比较简单的\(Prim\)算法 Part 1:最小生成树 ...

  5. Highways POJ-1751 最小生成树 Prim算法

    Highways POJ-1751 最小生成树 Prim算法 题意 有一个N个城市M条路的无向图,给你N个城市的坐标,然后现在该无向图已经有M条边了,问你还需要添加总长为多少的边能使得该无向图连通.输 ...

  6. SWUST OJ 1075 求最小生成树(Prim算法)

    求最小生成树(Prim算法) 我对提示代码做了简要分析,提示代码大致写了以下几个内容 给了几个基础的工具,邻接表记录图的一个的结构体,记录Prim算法中最近的边的结构体,记录目标边的结构体(始末点,值 ...

  7. 最小生成树,Prim算法与Kruskal算法,408方向,思路与实现分析

    最小生成树,Prim算法与Kruskal算法,408方向,思路与实现分析 最小生成树,老生常谈了,生活中也总会有各种各样的问题,在这里,我来带你一起分析一下这个算法的思路与实现的方式吧~~ 在考研中呢 ...

  8. 最小生成树—prim算法

    最小生成树prim算法实现 所谓生成树,就是n个点之间连成n-1条边的图形.而最小生成树,就是权值(两点间直线的值)之和的最小值. 首先,要用二维数组记录点和权值.如上图所示无向图: int map[ ...

  9. CDOJ 1146 A - 秋实大哥与连锁快餐店 最小生成树 Prim算法 稠密图

    题目链接 A - 秋实大哥与连锁快餐店 Time Limit:3000MS     Memory Limit:65535KB     64bit IO Format:%lld & %llu S ...

随机推荐

  1. 【noi 2.6_6045】开餐馆(DP)

    题意:有N个地址,从中选一些开餐馆,要保证相邻餐馆的距离大于k.问最大利润. 解法:f[i]表示在前 i 个地址中选的最大利润. 1 #include<cstdio> 2 #include ...

  2. uestc 1221 Ancient Go

    Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit  Status Y ...

  3. DNA Sequence POJ - 2778 AC自动机 && 矩阵快速幂

    It's well known that DNA Sequence is a sequence only contains A, C, T and G, and it's very useful to ...

  4. woj1002-Genesis woj1003-birthofnoah woj1004-noah's ark

    title: woj1002-Genesis date: 2020-03-05 categories: acm tags: [acm,woj] 输入输出考虑一下.easy #include <i ...

  5. 抓包 127.0.0.1 (loopback) 使用 tcpdump+wireshark

    直接使用 wireshark无法抓取 127.0.0.1环回的数据包,一种解决方法是先传到路由器再返回,但这样可能造成拥塞. Linux 先使用tcpdump抓包并输出为二进制文件,然后wiresha ...

  6. spark mllib als 参数

    在一定范围内按照排列组合方式对rank,iterations,lambda进行交叉评估(根据均方根误差),找到最小误差的组合,用于建立矩阵分解模型.Signature: ALS.train( rati ...

  7. SDN总结

    之前做项目用到了SDN,知道其作用,但是对其不是特别熟悉,今天特来总结一下相关知识点: 1. SDN的典型架构分为哪三层 主要分为应用层,控制层,和基础设施层: 2. SDN技术的关键点是 控制平面和 ...

  8. C++ part2

    为什么析构函数必须是虚函数?为什么C++默认的析构函数不是虚函数? references: nowcoder 将可能会被继承的父类的析构函数设置为虚函数,可以保证当我们new一个子类,然后使用基类指针 ...

  9. React & Strict Mode

    React & Strict Mode https://reactjs.org/docs/strict-mode.html#detecting-unexpected-side-effects ...

  10. 旅游玩乐 业务组件 UI 交互

    旅游玩乐 业务组件 UI 交互 旅游业务组件 ctrip PC web https://piao.ctrip.com/dest/t4651499.html M web https://m.ctrip. ...