1026 逃跑的拉尔夫

 时间限制: 1 s
 空间限制: 128000 KB
 题目等级 : 黄金 Gold
 
 
 
题目描述 Description

年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且车上装有用于发射车子移动路线的装置。

那个装置太旧了,以至于只能发射关于那辆车的移动路线的方向信息。

编写程序,通过使用一张小镇的地图帮助警察局找到那辆车。程序必须能表示出该车最终所有可能的位置。

小镇的地图是矩形的,上面的符号用来标明哪儿可以行车哪儿不行。“.”表示小镇上那块地方是可以行车的,而符号“X”表示此处不能行车。拉尔夫所开小车的初始位置用字符的“*”表示,且汽车能从初始位置通过。

汽车能向四个方向移动:向北(向上),向南(向下),向西(向左),向东(向右)。

拉尔夫所开小车的行动路线是通过一组给定的方向来描述的。在每个给定的方向,拉尔夫驾驶小车通过小镇上一个或更多的可行车地点。

输入描述 Input Description

输入文件的第一行包含两个用空格隔开的自然数R和C,1≤R≤50,1≤C≤50,分别表示小镇地图中的行数和列数。

以下的R行中每行都包含一组C个符号(“.”或“X”或“*”)用来描述地图上相应的部位。

接下来的第R+2行包含一个自然数N,1≤N≤1000,表示一组方向的长度。

接下来的N行幅行包含下述单词中的任一个:NORTH(北)、SOUTH(南)、WEST(西)和EAST(东),表示汽车移动的方向,任何两个连续的方向都不相同。

输出描述 Output Description

输出文件应包含用R行表示的小镇的地图(象输入文件中一样),字符“*”应该仅用来表示汽车最终可能出现的位置。

样例输入 Sample Input

4 5

.....

.X...

...*X

X.X..

3

NORTH

WEST

SOUTH

样例输出 Sample Output

.....

*X*..

*.*.X

X.X..

数据范围及提示 Data Size & Hint
 

分类标签 Tags 点此展开

 
# include <stdio.h>
# include <stdlib.h>
# include <iostream>
# include <string.h>
# include <queue>
# define cls(a) memset(a, , sizeof(a))
# define oo
# define ll long long
using namespace std; struct node
{
int x, y, d;
} s;
int n, m,tot;
int map[][],boo[][][],step[];
int dx[] = {, -, , , };
int dy[] = {, , , -, };
queue <node> Q;
inline void bfs()
{
boo[s.x][s.y][] = ;
s.d = ; //移动的方向
Q.push(s);//把s压入队列中
while(!Q.empty()){//如果队列不为空
node v=Q.front(); //把v变成与node定义相同的结构体,并使结构体v中各元素的值与node中各元素的值相同;
Q.pop();//弹出队首元素
v.x+=dx[step[v.d]];//从开始点开始项规定方向移动(这是第v.d次的移动,v.d代表移动方向);
v.y+=dy[step[v.d]];//同上;
if(v.x>&&v.x<=n&&v.y>&&v.y<=m&&!boo[v.x][v.y][v.d]&&map[v.x][v.y]) {//移动不超范围,并且在该方向下没走到过,并且没有围墙
if(v.d == tot) map[v.x][v.y] = ;//如果走完了,把该点记录为能走到的最后一个点
boo[v.x][v.y][v.d] = ;//否则标记该点走过
Q.push(v);//把结构体v压入队列;
if(v.d + <= tot)
v.d++,
Q.push(v);//如果没走完走,继续走
}
}
}
int main()
{
scanf("%d%d", &n, &m);//读入n,m;
for(int i = ; i <= n; i++)
for(int j = ; j <= m; j++){
char ch;
scanf(" %c", &ch); //输入字符
if(ch == '.') map[i][j] = ;//用map数组将字符数组转化为数字数组;
if(ch == '*') s.x = i, s.y = j, map[i][j] = ;//s.x记录下开始点的横坐标,s.y记录下开始点的纵坐标,开始点可走;
}
scanf("%d", &tot);//输入所走方向数;
for(int i = ; i <= tot; i++){
char ch[];
scanf(" %s", ch);//输入方向
if(ch[] == 'N') step[i] = ;
if(ch[] == 'S') step[i] = ;
if(ch[] == 'W') step[i] = ;
if(ch[] == 'E') step[i] = ;//用1,2,3,4四个数代替北南西东,用step数组存方向
}
bfs();//开始搜索 (重点)
for(int i = ; i <= n; i++, printf("\n"))
for(int j = ; j <= m; j++){
char ch = 'X';
if(map[i][j] == ) ch = '*';
if(map[i][j] == ) ch = '.';
printf("%c", ch);//输出结束后的状态图;
}
return ;
}
 广度优先搜索,搜每种情况下能到达的所有情况,然后对每种情况继续搜索,直至搜索完毕后输出;

最新文章

  1. Javascript 的执行环境(execution context)和作用域(scope)及垃圾回收
  2. Select Tree Node
  3. WC项目要求
  4. css 多个不定数量提交按钮居中显示,纯css解决
  5. asp.net mvc5 伪静态 WebForm
  6. iOS 设置 文字和 图片的位置
  7. FIFO分枝_限界算法
  8. javascript 与 java
  9. nodejs学习笔记之安装、入门
  10. cocoapods导入第三方库
  11. 设置高级的Logstash 管道
  12. Chapter 15_3 使用环境
  13. 一天就学会Android开发四大组件
  14. RabbitMQ 入门【精+转】
  15. QLayout删除所有布局
  16. git 入门教程之版本控制
  17. [转]fiddler 抓包 HTTPS 请求
  18. 在excel中如何利用vba通过网址读取网页title(网址是https的)?
  19. Python内置类型(6)——生成器
  20. signal函数的原型声明void (*signal(int signo, void (*fun(int))))(int)分析

热门文章

  1. poj3254 Corn Fields (状压DP)
  2. 7 天玩转 ASP.NET MVC — 第 1 天
  3. word中替换被批注的正文的值
  4. Java-开启Java之路
  5. PHP的 Mysqli扩展库的多语句执行
  6. JSON格式转换(javascript)
  7. linux C之getchar()非阻塞方式
  8. 安装Sublime Text 3插件的方法
  9. HDU 4793 Collision(2013长沙区域赛现场赛C题)
  10. angularjs获取参数方法