poj3026:http://poj.org/problem?id=3026

题意:在一个y行 x列的迷宫中,有可行走的通路空格’ ‘,不可行走的墙’#’,还有两种英文字母A和S,现在从S出发,要求用最短的路径L连接所有字母,输出这条路径L的总长度。
题解:一格的长度为1,而且移动的方法只有上、下、左、右,所以在无任何墙的情况下(根据题意的“分离”规则,重复走过的路不再计算因此当使用prim算法求L的长度时,根据算法的特征恰好不用考虑这个问题(源点合并很好地解决了这个问题),L就是最少生成树的总权值W由于使用prim算法求在最小生成树,因此无论哪个点做起点都是一样的,(通常选取第一个点),因此起点不是S也没有关系所以所有的A和S都可以一视同仁,看成一模一样的顶点就可以了剩下的问题关键就是处理 任意两字母间的最短距离,由于存在了“墙#” ,这个距离不可能单纯地利用坐标加减去计算,必须额外考虑,推荐用BFS(广搜、宽搜),这是本题的唯一难点,因为prim根本直接套用就可以了。

 #include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>s
#include<queue>
#include<string>
#define INF 10000000
using namespace std;
int xn,yn,top,pos;
int n,m;
char map[][];
int dist[][],lowcost[],g[][],visit[][];
struct Node{
int x;
int y;
int step;
};
struct Node1{
int x;
int y;
}node[];
void init(){
for(int i=;i<=xn;i++)
for(int j=;j<=yn;j++)
dist[i][j]=INF;
memset(visit,,sizeof(visit));
}
void bfs(Node1 a){
init();
dist[a.x][a.y]=;
queue<Node>Q;
Node temp;
temp.x=a.x;
temp.y=a.y;
temp.step=;
visit[a.x][a.y]=true;
Q.push(temp);
while(!Q.empty()){
Node tmp=Q.front();
Q.pop();
int x=tmp.x;
int y=tmp.y;
if(x>=&&map[x-][y]!='#'&&!visit[x-][y]){
visit[x-][y]=true;//bfs收索时候,一定要在入队之前标记,如果在出队
dist[x-][y]=tmp.step+;//时在标记,会使得一个元素在队列中可能会被加入多次。
temp.x=x-;
temp.y=y;
temp.step=tmp.step+;
Q.push(temp);
}
if(x<xn&&map[x+][y]!='#'&&!visit[x+][y]){
visit[x+][y]=true;
dist[x+][y]=tmp.step+;
temp.x=x+;
temp.y=y;
temp.step=tmp.step+;
Q.push(temp);
}
if(y>=&&map[x][y-]!='#'&&!visit[x][y-]){
visit[x][y-]=true;
dist[x][y-]=tmp.step+;
temp.x=x;
temp.y=y-;
temp.step=tmp.step+;
Q.push(temp);
}
if(y<yn&&map[x][y+]!='#'&&!visit[x][y+]){
visit[x][y+]=true;
dist[x][y+]=tmp.step+;
temp.x=x;
temp.y=y+;
temp.step=tmp.step+;
Q.push(temp);
}
}
}
void prim(int v0){
int sum=;
for(int i=;i<top;i++){
lowcost[i]=g[v0][i];
}
lowcost[v0]=-;
for(int i=;i<top-;i++){
int min=INF;
int v=-;
for(int j=;j<top;j++){
if(lowcost[j]<min&&lowcost[j]!=-){
min=lowcost[j];
v=j;
}
}
if(v!=-){
sum+=lowcost[v];
lowcost[v]=-;
for(int k=;k<top;k++)
if(lowcost[k]!=-&&g[v][k]<lowcost[k])
lowcost[k]=g[v][k];
}
}
printf("%d\n",sum);
}
int main(){
int cas;string line;
scanf("%d",&cas);
char sss[];
while(cas--){
top=;
scanf("%d%d",&yn,&xn);
gets(sss);//这里如果用gethchar()oj会判wa
for(int i=;i<=xn;i++){
getline(cin,line);//读取一整行 for(int j=;j<=yn;j++){
map[i][j]=line[j-];
if(map[i][j]!=' '&&map[i][j]!='#'){//记录每个A和S
node[top].x=i;
node[top++].y=j;
}
if(map[i][j]=='S'){//记录起点
pos=top-;
}
}
}
for(int i=;i<top;i++){
bfs(node[i]);//一遍bfs找出了所有其他点与改点的距离
for(int j=i+;j<top;j++){//建边
g[i][j]=g[j][i]=dist[node[j].x][node[j].y];
}
}
for(int i=;i<top;i++)//初始化
for(int j=;j<top;j++){
if(i==j)g[i][j]=;
else if(g[i][j]==)g[i][j]=INF;
}
prim(pos);
}
}

Borg Maze的更多相关文章

  1. Borg Maze(MST & bfs)

    Borg Maze Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9220   Accepted: 3087 Descrip ...

  2. POJ 3026 : Borg Maze(BFS + Prim)

    http://poj.org/problem?id=3026 Borg Maze Time Limit: 1000MS   Memory Limit: 65536K Total Submissions ...

  3. poj 3026 Borg Maze 最小生成树 + 广搜

    点击打开链接 Borg Maze Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7097   Accepted: 2389 ...

  4. POJ 3026 Borg Maze (最小生成树)

    Borg Maze 题目链接: http://acm.hust.edu.cn/vjudge/contest/124434#problem/I Description The Borg is an im ...

  5. POJ 3026 Borg Maze(bfs+最小生成树)

    Borg Maze Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6634   Accepted: 2240 Descrip ...

  6. poj 3026 Borg Maze (BFS + Prim)

    http://poj.org/problem?id=3026 Borg Maze Time Limit:1000MS     Memory Limit:65536KB     64bit IO For ...

  7. POJ 3026 Borg Maze

    Borg Maze Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7998   Accepted: 2675 Descrip ...

  8. POJ3026——Borg Maze(BFS+最小生成树)

    Borg Maze DescriptionThe Borg is an immensely powerful race of enhanced humanoids from the delta qua ...

  9. POJ3026 Borg Maze 2017-04-21 16:02 50人阅读 评论(0) 收藏

    Borg Maze Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 14165   Accepted: 4619 Descri ...

  10. Borg Maze(BFS+MST)

    Borg Maze http://poj.org/problem?id=3026 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions ...

随机推荐

  1. 晨曦之光 linux Crontab 使用(转)

    cron用法说明 cron的用法老是记不住,索性写下来备忘.下文内容大部分是根据<Cron Help Guide>翻译而来,有些部分是自己加上的. 全文如下: cron来源于希腊单词chr ...

  2. 用 Qt 中的 QDomDocument类 处理 XML 文件(上)

      我们可以看到,如果所要读取的XML文件不是很大,采用DOM读取方法还是很便捷的,由于我用的也是DOM树读取的方法,所以,本文所介绍的也主要是基于DOM的方法读取. 根据常用的操作,我简单的把对XM ...

  3. 判断IMEI或MEID是否合法

    /*----------------------------------------------- * 判断此字串所代表的IMEI或MEID是否合法 * @param imei * @author H ...

  4. Microsoft Windows Server 2008 R2 IIS7.5安装指南

    一.IIS安装步骤: 1.安装Windows Server 2008 R2(见 附录一) 2.配置计算机名称和IP地址(见 附录一) 3.配置成员服务器(见 附录一) 4.点击任务栏上的“服务器管理器 ...

  5. js--小结⑦---格式转换

  6. jsp页面表单的遍历要怎么写

    1.传统的方式使用request.getAttribute(“list”);获取表单的值, 2.也可以用struts2提供的标签进行遍历 备注 // 传统的接受参数方法 // String sfz=t ...

  7. html input 文本框的一些操作(限制输入...)

    1.取消按钮按下时的虚线框 在input里添加属性值 hideFocus 或者 HideFocus=true 2.只读文本框内容 在input里添加属性值 readonly 3.防止退后清空的TEXT ...

  8. Android--WebView控件

    WebView 一 简介: WebView一般用于将Android页面已HTML的形式展现,我们一般叫它HTML5开发: WebView可以使得网页轻松的内嵌到app里,还可以直接跟js相互调用,通过 ...

  9. sql - 获取日期中的年

    使用 YEAR函数, 如 --day为rain表中的字段. select YEAR(day) from t_rain

  10. CTE-递归[2]

    在此之前写过一个CTE的递归,取出了所有的子节点,基本上可以满足大多数的需求,这里我们来延伸一下:首先我们回顾下原来的场景 图片的上半部分递归查出某个节点的所有子节点,这个我们已经通过CTE实现了,可 ...