【wikioi】1026 逃跑的拉尔夫
算法:BFS
14.01.02 PS: 本人再次脑残,BFS又是写得那么脓肿,突然发现我原来什么搜索都是不会的呀。。
//2014-02-05已更新
*******************************2013-10-15*******************************
题目描述:
年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且车上装有用于发射车子移动路线的装置。
那个装置太旧了,以至于只能发射关于那辆车的移动路线的方向信息。
编写程序,通过使用一张小镇的地图帮助警察局找到那辆车。程序必须能表示出该车最终所有可能的位置。
小镇的地图是矩形的,上面的符号用来标明哪儿可以行车哪儿不行。“.”表示小镇上那块地方是可以行车的,而符号“X”表示此处不能行车。拉尔夫所开小车的初始位置用字符的“*”表示,且汽车能从初始位置通过。
汽车能向四个方向移动:向北(向上),向南(向下),向西(向左),向东(向右)。
拉尔夫所开小车的行动路线是通过一组给定的方向来描述的。在每个给定的方向,拉尔夫驾驶小车通过小镇上一个或更多的可行车地点。
此题要注意超空间和TLE,如果纯bfs的话肯定过不了2个点,所以加个三维数组判重(必须用3个,第3维表示用到方向的个数,要不然就错判了)
此题还要注意,这个BFS要沿着一个方向一直扩展下去,保持n不变(n是用到的方向数)
(这里不卡queue,我就不手打队列了)
其余的不多说,上代码:
#include <iostream>
#include <string>
#include <queue> using namespace std;
enum typemap{X, DOT, OK}; //自定义的地图,有3中状态,X表示‘X’,DOT表示‘.’,OK表示‘*’
enum fangxiang{N, S, W, E}; //自定义方向类型
//NORTH(北):N 、SOUTH(南):S 、WEST(西):W 、EAST(东):E
struct ma
{
int x, y, n; //n表示用到第几个
}f;
typemap map[52][52];
fangxiang fx[1050];
bool vis[52][52][1050]; //三维判重
int i, j, n, r, c;
char tem;
string temp;
queue<ma> q; int main()
{
cin >> r >> c;
for(i = 1; i <= r; i++) for(j = 1; j <= c; j++)
{
cin >> tem;
if(tem == '.') map[i][j] = DOT;
else if(tem == 'X') map[i][j] = X;
else {f.x = i; f.y = j; map[i][j] = OK;}
}
f.n = 1;
map[f.x][f.y] = DOT; //从这个方向搜的时候最后可能OK不存在(即不走回原点)故要把标志去掉
cin >> n;
for(i = 1; i <= n; i++)
{
cin >> temp;
if(temp=="NORTH") fx[i]=N;
else if(temp=="SOUTH") fx[i]=S;
else if(temp=="WEST") fx[i]=W;
else fx[i]=E;
}
q.push(f);
while(!q.empty())
{
f = q.front(); q.pop();
if(f.n > n) {map[f.x][f.y] = OK; continue;}
if(fx[f.n] == N)
{
f.n++;
while(f.x>1) //一直延展下去
{
if(map[f.x-1][f.y] == X || vis[f.x-1][f.y][f.n]) break;
f.x--;
q.push(f);
vis[f.x][f.y][f.n] = 1; //标志
}
}
else if(fx[f.n] == S)
{
f.n++;
while(f.x<r)
{
if(map[f.x+1][f.y] == X || vis[f.x+1][f.y][f.n]) break;
f.x++;
q.push(f);
vis[f.x][f.y][f.n] = 1;
}
}
else if(fx[f.n] == W)
{
f.n++;
while(f.y>1)
{
if(map[f.x][f.y-1] == X || vis[f.x][f.y-1][f.n]) break;
f.y--;
q.push(f);
vis[f.x][f.y][f.n] = 1;
}
}
else if(fx[f.n] == E)
{
f.n++;
while(f.y<c)
{
if(map[f.x][f.y+1] == X || vis[f.x][f.y+1][f.n]) break;
f.y++;
q.push(f);
vis[f.x][f.y][f.n] = 1;
}
}
}
for(i = 1; i <= r; i++)
{
for(j = 1; j <= c; j++)
switch (map[i][j])
{
case DOT:
cout << '.';
break;
case OK:
cout << '*';
break;
case X:
cout << 'X';
break;
}
cout << endl;
}
return 0;
}
*******************************2014-02-05*******************************
重写了一下,原理和上面差不多的,注意边界处理即可
#include <iostream>
#include <string>
using namespace std; const int maxq = 10000000,
maxn = 52; struct Map {
int x, y, c;
Map& operator= (Map& a) { x = a.x; y = a.y; c = a.c; return *this; }
}q[maxq]; int map[maxn][maxn], R, C, n;
bool vis[maxn][maxn][1003];
int dx[4] = {-1, 1, 0, 0}, dy[4] = {0, 0, -1, 1};
int fx[1003]; void bfs() {
int f = 0, l = 1;
Map t;
while(f != l) {
if(q[f].c > n) { map[q[f].x][q[f].y] = 2; f++; continue; }
t = q[f]; int w = fx[t.c];
t.c = q[f].c + 1;
t.x += dx[w]; t.y += dy[w];
while(t.x >= 1 && t.x <= R && t.y >= 1 && t.y <= C && map[t.x][t.y] != 1 && !vis[t.x][t.y][t.c]) {
vis[t.x][t.y][t.c] = 1;
q[l++] = t;
t.x += dx[w]; t.y += dy[w];
}
f++;
}
} int main() {
cin >> R >> C;
int i, j;
char t;
string str;
for(i = 1; i <= R; ++i) for(j = 1; j <= C; ++j) {
cin >> t;
if(t == 'X') map[i][j] = 1;
if(t == '*') q[0].x = i, q[0].y = j;
}
cin >> n;
for(i = 1; i <= n; ++i) {
cin >> str;
if(str[0] == 'N') fx[i] = 0;
else if(str[0] == 'S') fx[i] = 1;
else if(str[0] == 'W') fx[i] = 2;
else fx[i] = 3;
}
q[0].c = 1;
bfs();
for(i = 1; i <= R; ++i) {
for(j = 1; j <= C; ++j) if(map[i][j] == 0) cout << '.'; else if(map[i][j] == 1) cout << 'X'; else cout << '*';
cout << endl;
}
return 0;
}
【wikioi】1026 逃跑的拉尔夫的更多相关文章
- WIKIOI 1026 逃跑的拉尔夫 深度优先搜索
/* 1026 逃跑的拉尔夫 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆 ...
- code vs 1026 逃跑的拉尔夫
1026 逃跑的拉尔夫 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description 年轻的拉尔夫开玩笑地从一个小镇上偷走 ...
- codevs 1026 逃跑的拉尔夫 x
1026 逃跑的拉尔夫 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他 ...
- Codevs 1026 逃跑的拉尔夫
时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且 ...
- AC日记——逃跑的拉尔夫 codevs 1026 (搜索)
1026 逃跑的拉尔夫 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description 年轻的拉尔夫开玩笑地从一 ...
- Codevs1026 逃跑的拉尔夫
题目描述 Description 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且车上装有用于发射车子移动路线的装置. 那个装置太旧了,以至于只能发射关于那辆车的移动 ...
- 洛谷P1189 逃跑的拉尔夫(SEARCH)
洛谷1189 SEARCH 题目描述 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且车上装有用于发射车子移动路线的装置. 那个装置太旧了,以至于只能发射关于那辆车的 ...
- P1189 SEARCH(逃跑的拉尔夫)
P1189 SEARCH 题目描述 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且车上装有用于发射车子移动路线的装置. 那个装置太旧了,以至于只能发射关于那辆车的移 ...
- Codevs1026 SEARCH(逃跑的拉尔夫 )(BFS)
SEARCH 时间限制: 1 Sec 内存限制: 128 MB提交: 11 解决: 4[提交][状态][讨论版] 题目描述 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警 ...
随机推荐
- Linux rpm安装问题解决
1.安装时提示:warning: *.rpm: Header V3 RSA/SHA256 Signature, keykey ID c105b9de: NOKEY 解决的方法就是在rpm 语句后面加上 ...
- NYOJ 61传纸条(一) 双线程DP问题
http://www.cnblogs.com/HpuAcmer/archive/2012/05/06/2486591.html 题目链接:http://acm.nyist.net/JudgeOnlin ...
- windows下的C/C++精确计时
由于我要测试线性筛法的速度,用上了C/C++精确计时.此时传统的clock()方法不够用了,我们需要另一种测量的办法,即CPUTicks/CPUFreq.如何实现呢? #include <win ...
- hdparm测试硬盘性能
<1>Centos安装hdparm测试硬盘性能 一.安装hdparm yum install hdparm -y Linux学习,http:// linux.it.net.cn 二.评估读 ...
- Unable to mount the CD/DVD image virtualbox解决方法
转自: http://askubuntu.com/questions/321589/unable-to-mount-the-cd-dvd-image-on-the-machine-sandbox
- 关于Linux下进程间使用共享内存和信号量通信的时的编译问题
今天在编译一个使用信号量实现进程同步时,出现了库函数不存在的问题.如下图 编译结果实际上是说,没include相应的头文件,或是头文件不存在(即系统不支持该库函数) 但我man shm_open是可以 ...
- js 函数定义三种方式
<p>Js 函数定义的三种方式:</p> <br> <p>方式一:function</p> <script type="te ...
- 转关于垂直切分Vertical Sharding的粒度
垂直切分的粒度指的是在做垂直切分时允许几级的关联表放在一个shard里.这个问题对应用程序和sharding实现有着很大的影响. 关联打断地越多,则受影响的join操作越多,应用程序为此做出的妥协就越 ...
- Cocos2d-JS游戏导演
什么是游戏的导演 具体来说,Cocos2d-JS中的导演是一个对象,它负责设置游戏的运行环境,控制游戏的住循环并且管理场景和场景的切换. 导演的任务 Cocos2d-JS中导演对象名为:cc.dire ...
- css样式,层叠顺序属性z-index
在做项目的时候,居然单击后显示的顺序一直被别的li标签压着,最后终于找到了,是css的z-index属性赋值了,值越大,显示的层就越高 详情推荐百度百科:z-index z-index是针对网页显示中 ...