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. c语言实现n!算法

    最近一面学习数据结构,一面在做些c语言的题目.这个题目前些天碰到,和同学讨论了下.于是就用c语言实现n!(n=10000) 1 #include<stdio.h> 2 #define MA ...

  2. UVA11400 Lighting System Design(DP)

    You are given the task to design a lighting system for a huge conference hall. After doing a lot of ...

  3. 一篇文章图文并茂地带你轻松学完 JavaScript 闭包

    JavaScript 闭包 为了更好地理解 JavaScript 闭包,笔者将先从 JavaScript 执行上下文以及 JavaScript 作用域开始写起,如果读者对这方面已经了解了,可以直接跳过 ...

  4. CF1471-B. Strange List

    CF1471-B. Strange List 题意: 给定一个由\(n\)个数字组成的数组以及一个\(x\).现在从前往后遍历数组,若当前遍历的数字\(a[i]\)可以被\(x\)整除,那么就在数组的 ...

  5. K8S(03)核心插件-Flannel网络插件

    系列文章说明 本系列文章,可以基本算是 老男孩2019年王硕的K8S周末班课程 笔记,根据视频来看本笔记最好,否则有些地方会看不明白 需要视频可以联系我 K8S核心网络插件Flannel 目录 系列文 ...

  6. 弹性计算服务(Elastic Compute Service) / 云服务器 ECS

    计费方式选择 多种可选择计算费用的方式,可以包年包月,按流量计费,按资源规格计费(本文第四点)等等 地域位置选择 地域:地域指的是 ECS 实例所在的物理位置 地域位置如何选择: 根据访问业务的用户比 ...

  7. 地址解析协议ARP与逆地址解析协议RARP

    IP地址是用来通信的,但是和硬件地址是有区别的.物理地址是数据链路层和物理层使用的地址,IP地址是网络层及以上各层使用的地址. 发送数据时,数据从高层向下层传输,使用IP地址的IP数据报交给下层的数据 ...

  8. μC/OS-III---I笔记6---互斥信号量

    互斥信号量 操作系统中利用信号量解决进程间的同步和互斥(互斥信号量)的问题,在多道程序环境下,操作系统就是遮掩实现进程之间的同步和互斥.但是在使用的过程中厉害的前辈还是发现了这一优秀机制的缺陷,它会导 ...

  9. Node.js require 模块加载原理 All In One

    Node.js require 模块加载原理 All In One require 加载模块,搜索路径 "use strict"; /** * * @author xgqfrms ...

  10. Big O Complexity Graph

    Big O Complexity Graph Big O === O() 算法复杂度速查表 数据结构 数组排序算法 Quicksort O(n log(n)) O(n log(n)) O(n^2) O ...