这道题按照题意直接BFS即可,主要要注意题意中的相遇是指两种情况:一种是同时到达同一格子,另一种是在移动时相遇,如Paris在(1,2),而Helen在(1,2),若下一步Paris到达(1,1),而Helen达到(1,2),这种情况也算是相遇。

 #include<bits/stdc++.h>
using namespace std;
int _move[][] = {{-, }, {, }, {, -}, {, }};
int visit[][][][];
int Helen_move[];
int n,m;
char _map[][];
struct Node{
int x1, y1;//Paris
int x2, y2;//Helen
int step;
}; Node bfs(int x1, int y1, int x2, int y2, int n, int m){
Node front;
front.x1 = x1;
front.y1 = y1;
front.x2 = x2;
front.y2 = y2;
front.step = ;
queue<Node> q;
q.push(front);
visit[x1][y1][x2][y2] = ;
while(!q.empty()){
front = q.front(); q.pop();
if(front.step > ) {
return front;//若大于255,则返回
}
for(int i = ; i < ; i++){
int Paris_x = front.x1 + _move[i][];//走一步
int Paris_y = front.y1 + _move[i][];
if( <= Paris_x && Paris_x < n && <= Paris_y && Paris_y < m &&
_map[Paris_x][Paris_y] != '#' && _map[Paris_x][Paris_y] != '!'){
int k = Helen_move[i]; int Helen_x = front.x2 + _move[k][];
int Helen_y = front.y2 + _move[k][]; if( <= Helen_x && Helen_x < n && <= Helen_y && Helen_y < m){
if(_map[Helen_x][Helen_y] == '#'){//撞墙则不走
Helen_x = front.x2;
Helen_y = front.y2;
}
else if(_map[Helen_x][Helen_y] == '!') continue;//遇到熔浆 if(visit[Paris_x][Paris_y][Helen_x][Helen_y] == ) continue;
Node tmp = front;
tmp.x1 = Paris_x;
tmp.y1 = Paris_y;
tmp.x2 = Helen_x;
tmp.y2 = Helen_y;
tmp.path[tmp.step] = i;
tmp.step = front.step + ;
q.push(tmp);
visit[Paris_x][Paris_y][Helen_x][Helen_y] = ;
if(Paris_x == Helen_x && Paris_y == Helen_y){//直接相遇
return tmp;
}
if(Paris_x == front.x2 && Paris_y == front.y2 &&
Helen_x == front.x1 && Helen_y == front.y1){
return tmp;//交差相遇
}
} }
}
}
front.step = ;
return front;
}
int main(){
cin >> n >> m; int x1, y1;
int x2, y2;
memset(visit, , sizeof(visit));
memset(Helen_move, , sizeof(Helen_move));
for(int i = ; i < n; i++){
for(int j = ; j < m; j++){
cin >> _map[i][j];
if(_map[i][j] == 'P'){//Paris的位置
x1 = i;
y1 = j;
}
if(_map[i][j] == 'H'){//Helen的位置
x2 = i;
y2 = j;
}
}
} for(int i = ; i < ; i++){
char c;
cin >> c;
if(c == 'N')Helen_move[i] = ;//Paris走时Helen的方向
else if(c == 'S')Helen_move[i] = ;
else if(c == 'W')Helen_move[i] = ;
else if(c == 'E')Helen_move[i] = ;
}
Node tmp = bfs(x1, y1, x2, y2, n, m);
if(tmp.step > ) cout << "Impossible" << endl;
else{
cout << tmp.step << endl;
} } /*
5 5
#####
#P#.#
#H!.#
#.#.#
#####
WNSE
*/

Sicily 1215: 脱离地牢(BFS)的更多相关文章

  1. sicily 1215. 脱离地牢

    Description 在一个神秘的国度里,年轻的王子Paris与美丽的公主Helen在一起过着幸福的生活.他们都随身带有一块带磁性的阴阳魔法石,身居地狱的魔王Satan早就想得到这两块石头了,只要把 ...

  2. 20180610模拟赛T1——脱离地牢

    Description 在一个神秘的国度里,年轻的王子Paris与美丽的公主Helen在一起过着幸福的生活.他们都随身带有一块带磁性的阴阳魔法石,身居地狱的魔王Satan早就想着得到这两块石头了,只要 ...

  3. Sicily 1048: Inverso(BFS)

    题意是给出一个3*3的黑白网格,每点击其中一格就会使某些格子的颜色发生转变,求达到目标状态网格的操作.可用BFS搜索解答,用vector储存每次的操作 #include<bits/stdc++. ...

  4. sicily 题目分类

    为了方便刷题,直接把分类保存下来方便来找. 转自:http://dengbaoleng.iteye.com/blog/1505083 [数据结构/图论] 1310Right-HeavyTree笛卡尔树 ...

  5. 地牢逃脱 (BFS)

    题意:给定一个 n 行 m 列的地牢,其中 '.' 表示可以通行的位置,'X' 表示不可通行的障碍,牛牛从 (x0 , y0 ) 位置出发,遍历这个地牢,和一般的游戏所不同的是,他每一步只能按照一些指 ...

  6. 2019 校内赛 RPG的地牢猎手(bfs+优先队列)

    Problem Description Luke最近沉迷一款RPG游戏,游戏中角色可以进入地牢关卡,只要顺利走出地牢就可以获得奖励.地牢表示为n行m列的块矩阵,其中每个块只可以是障碍块.入口.出口或数 ...

  7. BFS简单题套路_Codevs 1215 迷宫

    BFS 简单题套路 1. 遇到迷宫之类的简单题,有什么行走方向的,先写下面的 声明 ; struct Status { int r, c; Status(, ) : r(r), c(c) {} // ...

  8. Sicily 1444: Prime Path(BFS)

    题意为给出两个四位素数A.B,每次只能对A的某一位数字进行修改,使它成为另一个四位的素数,问最少经过多少操作,能使A变到B.可以直接进行BFS搜索 #include<bits/stdc++.h& ...

  9. Sicily 1051: 魔板(BFS+排重)

    相对1150题来说,这道题的N可能超过10,所以需要进行排重,即相同状态的魔板不要重复压倒队列里,这里我用map储存操作过的状态,也可以用康托编码来储存状态,这样时间缩短为0.03秒.关于康托展开可以 ...

随机推荐

  1. 做中学(Learning by Doing)之背单词-扇贝网推荐

    做中学(Learning by Doing)之背单词-扇贝网推荐 看完杨贵福老师(博客,知乎专栏,豆瓣)的「继续背单词,8个月过去了」,我就有写这篇文章的冲动了,杨老师说: 有时候我会感觉非常后悔,如 ...

  2. ElasticSearch第四步-查询详解

    ElasticSearch系列学习 ElasticSearch第一步-环境配置 ElasticSearch第二步-CRUD之Sense ElasticSearch第三步-中文分词 ElasticSea ...

  3. 小谈Jquery框架

    现在Jquery框架对于开发人员基本上是无人不知,无人不晓了,用起来十分的方便,特别是选择器十分强大,提高了我们的开发速度.但是好多人也只是停留在了会用的基础上,我个人觉得会用一个框架不算什么,只能说 ...

  4. autofac与unity注册类型的几个小区别

    //以下两个注册,在Unity中是默认的 //注册控制器,否则不管接口注入还是属性注入都获取不到服务实例 Builder.RegisterControllers(typeof(MvcApplicati ...

  5. Hibernate+EhCache配置二级缓存

    步骤: 第一步:加入ehcache.jar 第二步: 在src目录下新建一个文件,名为:ehcache.xml 第三步:在hibernate配置文件的<session-factory>下配 ...

  6. jQuery实现动态分割

    由jQuery实现上下.左右动态改变左右.上下两个div的大小,需要自己引入jquery1.8.0.min.js包 可用于页面布局. //============================ind ...

  7. HTML5 之 FileReader(图片上传)

    1.FileReader接口的方法 FileReader接口有4个方法,其中3个用来读取文件,另一个用来中断读取.无论读取成功或失败,方法并不会返回读取结果,这一结果存储在result属性中. Fil ...

  8. POJ 3204 Ikki's Story I - Road Reconstruction

    Ikki's Story I - Road Reconstruction Time Limit: 2000MS   Memory Limit: 131072K Total Submissions: 7 ...

  9. x509数字证书导入-然后删除自身

    这种程序的使用场景,需要给客户一个证书,但不能把证书直接给他让他安装,程序中需要用到给客户的私钥,但又不允许客户将这个证书再去授权给其它人. 重点并不是代码,是如何对用户隐藏需要添加的资源 ,以文本为 ...

  10. ASP.NET Forms 身份验证

    ASP.NET Forms 身份验证 在开发过程中,我们需要做的事情包括: 1. 在 web.config 中设置 Forms 身份验证相关参数.2. 创建登录页. 登录页中的操作包括: 1. 验证用 ...