快速切题 poj 3026 Borg Maze 最小生成树+bfs prim算法 难度:0
Borg Maze
| Time Limit: 1000MS | Memory Limit: 65536K | |
| Total Submissions: 8905 | Accepted: 2969 |
Description
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
Output
Sample Input
2
6 5
#####
#A#A##
# # A#
#S ##
#####
7 7
#####
#AAA###
# A#
# S ###
# #
#AAA###
#####
Sample Output
8
11 思路:bfs得外星人间最小距离(假设人类是第0号外星人),prim得最小生成树
#include<cstdio>
#include <cstring>
#include <queue>
#include <assert.h>
using namespace std;
char maz[202][202];
bool vis[202][202];
int d[201][202][202];
int alien[201][2];
int numa;
int x,y;
int sx,sy;
int e[202][202];
typedef pair<int,int> P;
queue<P> que;
const int dx[4]={0,0,-1,1};
const int dy[4]={-1,1,0,0};
bool used[101];
void bfs(){
sx=sy=-1;//处理迷宫
numa=0;
memset(vis,0,sizeof(vis));
for(int i=0;i<y;i++){
for(int j=0;j<x;j++){
if(maz[i][j]=='S'){
sx=j;
sy=i;
break;
}
}
}
assert(sx!=-1&&sy!=-1);
vis[sy][sx]=true;
d[0][sy][sx]=0;
alien[numa][0]=sy;
alien[numa++][1]=sx;
que.push(P(sy,sx));
while(!que.empty()){//从人类出发bfs
P p=que.front();
que.pop();
for(int i=0;i<4;i++){
int ny=p.first+dy[i];
int nx=p.second+dx[i];
if(nx>=0&&nx<x&&ny>=0&&ny<y&&!vis[ny][nx]&&maz[ny][nx]!='#'){
d[0][ny][nx]=d[0][p.first][p.second]+1;
vis[ny][nx]=true;
que.push(P(ny,nx));
if(maz[ny][nx]=='A'){
alien[numa][0]=ny;
alien[numa++][1]=nx;
}
}
}
}
for(int ai=1;ai<numa;ai++){//从每个外星人出发bfs
memset(vis,0,sizeof(vis));
int ay=alien[ai][0],ax=alien[ai][1];
d[ai][ay][ax]=0;
que.push(P(ay,ax));
vis[ay][ax]=true;
while(!que.empty()){
P p=que.front();
que.pop();
for(int i=0;i<4;i++){
int ny=p.first+dy[i];
int nx=p.second+dx[i];
if(nx>=0&&nx<x&&ny>=0&&ny<y&&!vis[ny][nx]&&maz[ny][nx]!='#'){
d[ai][ny][nx]=d[ai][p.first][p.second]+1;
vis[ny][nx]=true;
que.push(P(ny,nx));
}
}
}
}
for(int i=0;i<numa;i++){//建图
//int ay=alien[i][0],ax=alien[i][1];
for(int j=0;j<numa;j++){
int ay1=alien[j][0],ax1=alien[j][1];
e[i][j]=d[i][ay1][ax1];
}
}
}
priority_queue <P,vector<P>, greater <P> > pque;
int prim(){
memset(used,0,sizeof(used));
used[0]=true;
int unum=1;
for(int i=1;i<numa;i++){
pque.push(P(e[0][i],i));
}
int ans=0;
while(unum<numa){
int t=pque.top().second;
int td=pque.top().first;
pque.pop();
if(used[t])continue;
ans+=td;
used[t]=true;
unum++;
for(int i=0;i<numa;i++){
if(!used[i]){
pque.push(P(e[t][i],i));
}
}
}
while(!pque.empty())pque.pop();
return ans;
}
int main(){
int t;
scanf("%d",&t);
while(t--){
scanf("%d%d",&x,&y);
gets(maz[0]);//抛弃空行
for(int i=0;i<y;i++){
gets(maz[i]);
}
bfs();
int ans=prim();
printf("%d\n",ans);
}
}
快速切题 poj 3026 Borg Maze 最小生成树+bfs prim算法 难度:0的更多相关文章
- poj 3026 Borg Maze (最小生成树+bfs)
有几个错误,调试了几个小时,样例过后 1Y. 题目:http://poj.org/problem?id=3026 题意:就是让求A们和S的最小生成树 先用bfs找每两点的距离,再建树.没剪枝 63MS ...
- poj 3026 Borg Maze 最小生成树 + 广搜
点击打开链接 Borg Maze Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7097 Accepted: 2389 ...
- 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 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6634 Accepted: 2240 Descrip ...
- POJ 3026 --Borg Maze(bfs,最小生成树,英语题意题,卡格式)
Borg Maze Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 16625 Accepted: 5383 Descri ...
- 快速切题 poj 2993 Emag eht htiw Em Pleh 模拟 难度:0
Emag eht htiw Em Pleh Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 2806 Accepted: ...
- 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 + Prim)
http://poj.org/problem?id=3026 Borg Maze Time Limit: 1000MS Memory Limit: 65536K Total Submissions ...
- POJ - 3026 Borg Maze BFS加最小生成树
Borg Maze 题意: 题目我一开始一直读不懂.有一个会分身的人,要在一个地图中踩到所有的A,这个人可以在出发地或者A点任意分身,问最少要走几步,这个人可以踩遍地图中所有的A点. 思路: 感觉就算 ...
随机推荐
- linux 下安装python3
这篇真的很好 没报错一次通过了 https://www.cnblogs.com/kimyeee/p/7250560.html
- SHUOJ Arithmetic Sequence (FFT)
链接:http://acmoj.shu.edu.cn/problem/533/ 题意:求一个序列中,有多少三元组(其中元素不重复)在任意的排列下能构成等差数列. 分析:等差数列:\(A_j-A_i=A ...
- WLAN QOS
1. 理解WLAN QOS 1.1 WLAN QOS简介 802.11的WLAN网络为用户提供了公平竞争无线资源的无线接入服务,但不同的应用需求对于网络的要求是不同的,而原始802.11网 ...
- CSS中定义a:link、a:visited、a:hover、a:active顺序
a :link.a:hover.a:visited这几个元素,定义CSS时候的顺序不同,也会直接导致链接显示的效果不同. eg:让未访问链接颜色为red,活动链接为yellow,已访问链接为green ...
- HDFS数据块
磁盘也是由数据块组成的,一般默认大小是512字节,构建磁盘之上的文件系统一般是磁盘块的整数倍. HDFS也是采用块管理的,但是比较大,在Hadoop1.x中默认大小是64M,Hadoo ...
- .NET BETWEEN方法
Between 值范围比较 可以判断一个值是否落在区间范围值中. public static bool Between<T>(this T me, T lower, T upper) wh ...
- Spark高级数据分析· 3推荐引擎
推荐算法流程 推荐算法 预备 wget http://www.iro.umontreal.ca/~lisa/datasets/profiledata_06-May-2005.tar.gz cd /Us ...
- 照着官网来安装openstack pike之neutron安装
neutron组件安装分为控制节点和计算节点,还是先从控制节点安装 1.前提条件,数据库为nova创建库和账户密码来连接数据库 # mysql -u root -p MariaDB [(none)]& ...
- C++第二次上机5-5
建立一个复数类Complex,实数和虚数是其私有数据成员: 建立复数类的无参和参数化构造函数: 建立一个 *(乘号)的运算符重载,以便于对两个复数直接进行乘法运算: 建立输出函数void displa ...
- 仔细讨论 C/C++ 字节对齐问题⭐⭐
原文:https://www.cnblogs.com/AlexMiller/p/5509609.html 字节对齐的原因 为了提高 CPU 的存储速度,编译器会对 struct 和 union的存储进 ...