POJ 3026 Borg Maze
| Time Limit: 1000MS | Memory Limit: 65536K | |
| Total Submissions: 7998 | Accepted: 2675 |
Description
subspace network that insures each member is given constant supervision and guidance.
Your task is to help the Borg (yes, really) by developing a program which helps the Borg to estimate the minimal cost of scanning a maze for the assimilation of aliens hiding in the maze, by moving in north, west, east, and south steps. The tricky thing is
that the beginning of the search is conducted by a large group of over 100 individuals. Whenever an alien is assimilated, or at the beginning of the search, the group may split in two or more groups (but their consciousness is still collective.). The cost
of searching a maze is definied as the total distance covered by all the groups involved in the search together. That is, if the original group walks five steps, then splits into two groups each walking three steps, the total distance is 11=5+3+3.
Input
a space `` '' stands for an open space, a hash mark ``#'' stands for an obstructing wall, the capital letter ``A'' stand for an alien, and the capital letter ``S'' stands for the start of the search. The perimeter of the maze is always closed, i.e., there
is no way to get out from the coordinate of the ``S''. At most 100 aliens are present in the maze, and everyone is reachable.
Output
Sample Input
2
6 5
#####
#A#A##
# # A#
#S ##
#####
7 7
#####
#AAA###
# A#
# S ###
# #
#AAA###
#####
Sample Output
8
11
最小生成树问题,主要是要求出点点距离,即字母间边权。这里用BFS求出了边权,用prim算法求出了最小生成树路径。
AC代码例如以下:
<pre name="code" class="cpp">#include<iostream>
#include<queue>
#include<cstring>
#include<cstdio>
#define inf 100000
using namespace std; char map[60][60];
int vis[60][60],v[60][60];
int n,m,tt,ans;
int dx[4]={-1,0,1,0};
int dy[4]={0,1,0,-1}; struct H
{
int h,z;
}a[10005]; int w[251][251],lc[251],vv[60][60];//W是边权记录,LCprim算法运用,VV记录第几个字母的坐标
struct HH
{
int h,z,st;
}; int bfs(int h,int z)
{
int i;
v[h][z]=1;
queue <HH> q;
HH a,b,c;
a.h=h;
a.z=z;
a.st=0;
q.push(a);
while(!q.empty())
{
b=q.front();
q.pop();
if(vv[b.h][b.z])//统计边权
{
w[vv[h][z]][vv[b.h][b.z]]=b.st;
w[vv[b.h][b.z]][vv[h][z]]=b.st;
//cout<<vv[h][z]<<" "<<vv[b.h][b.z]<<" "<<b.st<<endl;
} for(i=0;i<4;i++)
{
c.h=b.h+dx[i];
c.z=b.z+dy[i];
if(c.h>=0&&c.h<n&&c.z>=0&&c.z<m&&map[c.h][c.z]!='#'&&!v[c.h][c.z])
{
v[c.h][c.z]=1;
c.st=b.st+1;
q.push(c);
}
}
}
} void prim()
{
int i,j;
int m,id;
for(i=1;i<tt;i++)
{
lc[i]=w[1][i];
} lc[1]=0;
for(j=1;j<tt-1;j++)
{
m=inf;
for(i=1;i<tt;i++)
if(lc[i]!=0&&lc[i]<m)
{m=lc[i];id=i;}
ans+=m;
lc[id]=0;
for(i=1;i<tt;i++)
{
if(lc[i]!=0&&lc[i]>w[id][i])
lc[i]=w[id][i];
}
} } int main()
{
int i,j,l;
int t;
char c[10];
scanf("%d",&t);
gets(c);
while(t--)
{
tt=1;
memset(vis,0,sizeof vis );
cin>>m>>n;
gets(c);
for(i=0;i<n;i++)
gets(map[i]);
//for(i=0;i<n;i++)
//cout<<map[i]<<endl;
int bj=0;
memset(vv,0,sizeof vv);
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
if(map[i][j]=='A'||map[i][j]=='S')
{
vv[i][j]=tt++;//记录字母序号及个数
}
}
for(i=1;i<tt;i++)
for(j=1;j<=i;j++)
if(i==j)
w[i][j]=0;
else {
w[i][j]=inf;
w[j][i]=inf;
}
for(i=0;i<n;i++)
for(j=0;j<m;j++)
{
if((map[i][j]=='A'||map[i][j]=='S')&&!vis[i][j])
{
vis[i][j]=1;
memset(v,0,sizeof v);
bfs(i,j);//求出这个字母到各个字母产生的边权
} } ans=0;
prim();//prim算法的运用
cout<<ans<<endl;
}
return 0;
}
POJ 3026 Borg Maze的更多相关文章
- poj 3026 Borg Maze (BFS + Prim)
http://poj.org/problem?id=3026 Borg Maze Time Limit:1000MS Memory Limit:65536KB 64bit IO For ...
- POJ 3026 Borg Maze【BFS+最小生成树】
链接: http://poj.org/problem?id=3026 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=22010#probl ...
- POJ - 3026 Borg Maze BFS加最小生成树
Borg Maze 题意: 题目我一开始一直读不懂.有一个会分身的人,要在一个地图中踩到所有的A,这个人可以在出发地或者A点任意分身,问最少要走几步,这个人可以踩遍地图中所有的A点. 思路: 感觉就算 ...
- POJ 3026 Borg Maze(bfs+最小生成树)
Borg Maze Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6634 Accepted: 2240 Descrip ...
- poj 3026 Borg Maze 最小生成树 + 广搜
点击打开链接 Borg Maze Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7097 Accepted: 2389 ...
- POJ 3026 Borg Maze (最小生成树)
Borg Maze 题目链接: http://acm.hust.edu.cn/vjudge/contest/124434#problem/I Description The Borg is an im ...
- poj 3026 Borg Maze (bfs + 最小生成树)
链接:poj 3026 题意:y行x列的迷宫中,#代表阻隔墙(不可走).空格代表空位(可走).S代表搜索起点(可走),A代表目的地(可走),如今要从S出发,每次可上下左右移动一格到可走的地方.求到达全 ...
- 快速切题 poj 3026 Borg Maze 最小生成树+bfs prim算法 难度:0
Borg Maze Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8905 Accepted: 2969 Descrip ...
- POJ 3026 --Borg Maze(bfs,最小生成树,英语题意题,卡格式)
Borg Maze Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 16625 Accepted: 5383 Descri ...
随机推荐
- MOSS 2010:Visual Studio 2010开发体验(14)——列表开发之事件接收器
转:http://boke.25k5.com/kan141919.html 通过前面几篇,我们已经完成了内容类型,列表定义,列表实例g 8h"@的开发.本篇继续讲解列表中的一个重要环节- ...
- 【转】使用NetBeans和Eclipse开发PHP应用程序
[51CTO独家特稿]各位用户如果单独看NetBeans和Eclipse的市场占有率,你可能会认为使用其中任何一种IDE开发PHP应用程序都没有 问题,例如: 1.NetBeans:一款开源的集成开发 ...
- .NET之美——C# 中的委托和事件
C# 中的委托和事件 文中代码在VS2005下通过,由于VS2003(.Net Framework 1.1)不支持隐式的委托变量,所以如果在一个接受委托类型的位置直接赋予方法名,在VS2003下会报错 ...
- 改变DEV控件的字体 z
改变所有的组件字体,使用AppearanceObject.DefaultFont属性:static void Main() { DevExpress.Utils.AppearanceObject ...
- C#控制定位Word光标移动到任意行或者最后一行,取得光标位置等操作
C#控制定位Word光标移动到任意行或者最后一行,取得光标位置等操作 http://blog.csdn.net/jglie/article/details/7394256 十一.上下左右移动光标位 p ...
- Handling HTTP 404 Error in ASP.NET Web API
Introduction: Building modern HTTP/RESTful/RPC services has become very easy with the new AS ...
- DataTable行转列
/// <summary> /// DataTable行转列 /// </summary> /// <param name="dtable">需 ...
- ARM处理机模式--内部寄存器
处理器模式 用户模式(user)简称usr 快速中断模式(FIQ)简称fiq 外部中断模式(IRQ)简称irq 特权模式(supervisor)简称sve 数据访问终止模式(abort)简称abt 未 ...
- 详谈C++保护成员和保护继承
protected 与 public 和 private 一样是用来声明成员的访问权限的.由protected声明的成员称为“受保护的成员”,或简称“保护成员”.从类的用户角度来看,保护成员等价于私有 ...
- Google Maps API显示地图的小示例
来源:http://www.ido321.com/1089.html 效果(新版Firefox中测试): 代码: <!DOCTYPE> <html> <head> ...