Superbot


Time Limit: 2 Seconds      Memory Limit: 65536 KB

Superbot is an interesting game which you need to control the robot on an N*M grid map.

As you see, it's just a simple game: there is a control panel with four direction left (1st position), right (2nd), up (3rd) and down (4th). For each second, you can do exact one of the following operations:

  • Move the cursor to left or right for one position. If the cursor is on the 1st position and moves to left, it will move to 4thposition; vice versa.
  • Press the button. It will make the robot move in the specific direction.
  • Drink a cup of hot coffee and relax. (Do nothing)

However, it's too easy to play. So there is a little trick: Every P seconds the panel will rotate its buttons right. More specifically, the 1st position moves to the 2nd position; the 2nd moves to 3rd; 3rd moves to 4th and 4th moves to 1st. The rotating starts at the beginning of the second.

Please calculate the minimum time that the robot can get the diamond on the map.

At the beginning, the buttons on the panel are "left", "right", "up", "down" respectively from left to right as the picture above, and the cursor is pointing to "left".

Input

There are multiple test cases. The first line of input contains an integer T indicating the number of test cases. For each test case:

The first line contains three integers NM (2 <= NM <= 10) and P (1 <= P <= 50), which represent the height of the map, the width of the map and the period that the panel changes, respectively.

The following lines of input contains N lines with M chars for each line. In the map, "." means the empty cell, "*" means the trap which the robot cannot get in, "@" means the initial position of the robot and "$" means the diamond. There is exact one robot and one diamond on the map.

Output

For each test case, output minimum time that the robot can get the diamond. Output "YouBadbad" (without quotes) if it's impossible to get the diamond.

Sample Input

4
3 4 50
@...
***.
$...
5 5 2
.....
..@..
.*...
$.*..
.....
2 3 1
*.@
$.*
5 5 2
*****
..@..
*****
$....
.....

Sample Output

12
4
4
YouBadbad

Hint

For the first example: 
0s: start
1s: cursor move right (cursor is at "right")
2s: press button (robot move right)
3s: press button (robot move right)
4s: press button (robot move right)
5s: cursor move right (cursor is at "up")
6s: cursor move right (cursor is at "down")
7s: press button (robot move down)
8s: press button (robot move down)
9s: cursor move right (cursor is at "left")
10s: press button (robot move left)
11s: press button (robot move left)
12s: press button (robot move left)

For the second example:
0s: start
1s: press button (robot move left)
2s: press button (robot move left)
--- panel rotated ---
3s: press button (robot move down, without changing cursor)
4s: press button (robot move down)

For the third example:
0s: start
1s: press button (robot move left)
--- panel rotated ---
2s: press button (robot move down)
--- panel rotated ---
3s: cursor move left (cursor is at "right")
--- panel rotated ---
4s: press button (robot move left)


题目描述:

给定一张图,有一个键盘,通过键盘可以控制机器人的行走方向,

求从@到¥处的最短距离,'.'表示通路,;'*'表示不同,每隔p秒键盘旋转一次。

这题第一反应不知为何是深搜,其实深搜也可以吧,通过不同的行走方式,到达¥处,在@的四个方向处调用

dfs(),维护最小值,不过没写。还是写宽搜吧。

渐渐的感到搜索算法跟dp差不多嘛。状态*选择。

不过之前的想法是按机器人所在位置为状态,进行四个方向的搜索,如果到达p

秒,进行旋转,不过要是在对方向键的移动中,旋转时间到了,怎么办?。

看了别人的代码,就设立状态[i][j][cur][times]表示每秒机器人所在位置,以及光标所处方向键,

此时所用时间,用结构体存储。

有四种选择,1,按着光标方向走 2 光标左移 3 光标右移 4 光标不动 ,至于每隔p秒旋转一次,

如果下一秒要旋转,那么有两种方式,a 这一秒先旋转,再做选择,b 先做选择,下一秒再做旋转。

不知为何b方式代码不能过。设立d[i][j][cur]表示此种状态有没有被选择过;用v[i][j]表示i,j位置有没有走过。

由于是宽搜,先搜到的就是最短距离。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
#define maxn 50
using namespace std;
int N,M,P;
char a[maxn][maxn];
int d[maxn][maxn][];
int v[maxn][maxn];
struct node
{
int x,y,cur,times;
};
int walk[][]={,-,,,-,,,};
inline void init()
{
memset(d,,sizeof(d));
memset(v,,sizeof(v));
memset(a,,sizeof(a));
}
int rolate(int des)
{
switch(des)
{
case :
return ;
case :
return ;
case :
return ;
case :
return ;
}
}
void solve()
{
node sou;
int ok=;
for(int i=;i<=N;i++)
{
for(int j=;j<=M;j++)
{
if(a[i][j]=='@')
{
sou.x=i;sou.y=j;sou.cur=;sou.times=;
ok=;
break;
}
}
if(ok==)
break;
} queue <node> que;
// v[sou.x][sou.y]=1;
d[sou.x][sou.y][sou.cur]=;
que.push(sou);
while(!que.empty())
{
node _current=que.front();
que.pop();
//printf("%d %d %d当前时间:%d\n",_current.x,_current.y,_current.cur,_current.times);
node _next; _next.x=_current.x+walk[_current.cur][];
_next.y=_current.y+walk[_current.cur][];
_next.cur=_current.cur; //按下光标
_next.times=_current.times;
if(_next.x>= && _next.x<=N && _next.y>= && _next.y<=M)
{
if(v[_next.x][_next.y]==)
{
if(a[_next.x][_next.y]=='.')
{
// v[_next.x][_next.y]=1;
//d[_next.x][_next.y][_next.cur]=1;
_next.times++;
if(_next.times%P==)
{
_next.cur=rolate(_next.cur);
d[_next.x][_next.y][_next.cur]=; }
// printf("走%d %d %d %d\n",_next.x,_next.y,_next.cur,_next.times);
que.push(_next);
}
else if(a[_next.x][_next.y]=='$')
{
_next.times++;
printf("%d\n",_next.times);
return ;
}
} } if((_current.times+)%P==)
_current.cur=rolate(_current.cur);
_next.x=_current.x;
_next.y=_current.y; _next.cur=(_current.cur+)%; //光标左移
_next.times=_current.times;
if(d[_next.x][_next.y][_next.cur]==)
{
d[_next.x][_next.y][_next.cur]=;
_next.times++;
// if(_next.times%P==0) //选择此时旋转,为何不行?
// _next.cur=rolate(_next.cur);
// printf("左移%d\n",_next.times);
que.push(_next);
} _next.cur=(_current.cur+)%; //光标右移
_next.times=_current.times;
if(d[_next.x][_next.y][_next.cur]==)
{
d[_next.x][_next.y][_next.cur]=;
_next.times++;
// if(_next.times%P==0)
// _next.cur=rolate(_next.cur);
// printf("右移%d\n",_next.times);
que.push(_next);
} // if(que.size()==1)
// break;
_next.cur=_current.cur; //光标不动
_next.times=_current.times;
if( d[_next.x][_next.y][_next.cur]== )
{
d[_next.x][_next.y][_next.cur]=;
_next.times++;
//if(_next.times%P==0)
// _next.cur=rolate(_next.cur);
// printf("不动%d\n",_next.times);
que.push(_next);
}
}
printf("YouBadbad\n");
}
int main()
{
//freopen("test.txt", "r", stdin);
int T;
scanf("%d",&T);
while(T--)
{
init();
scanf("%d%d%d",&N,&M,&P);
for(int i=;i<=N;i++)
scanf("%s",a[i]+);
solve();
} }

zoj 3865的更多相关文章

  1. BFS+模拟 ZOJ 3865 Superbot

    题目传送门 /* BFS+模拟:dp[i][j][p] 表示走到i,j,方向为p的步数为多少: BFS分4种情况入队,最后在终点4个方向寻找最小值:) */ #include <cstdio&g ...

  2. ZOJ - 3865 Superbot 【BFS】

    题目链接 http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3865 思路 一个迷宫题 但是每次的操作数和普通的迷宫题不一样 0 ...

  3. ZOJ 3865 Superbot(优先队列--模板)

    题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5477 主要思路:1.从一个点(cur)到它相邻的点(next),所需 ...

  4. zoj.3865.Superbot(bfs + 多维dp)

    Superbot Time Limit: 2 Seconds      Memory Limit: 65536 KB Superbot is an interesting game which you ...

  5. Zoj 3865 Superbot

    按规则移动机器人 , 问是否能拾得宝藏 . 加了一个控制板 , 还增加了一个控制板移动周期 p 将移动周期变换一下 , 移动一次  就相当于光标向左不耗费时间的移动了一格 搜索思路 : 搜索当前格子到 ...

  6. 浙江大学2015年校赛F题 ZOJ 3865 Superbot BFS 搜索

    不知道为什么比赛的时候一直想着用DFS 来写 一直想剪枝结果还是TLE = = 这题数据量不大,又是问最优解,那么一般来说是用 BFS 来写 int commandi[4] = {1, 2, 3, 4 ...

  7. ZOJ Problem Set - 3865 Superbot (bfs)

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5477 大牛博客:http://www.cnblogs.com/kylehz/p ...

  8. ZOJ People Counting

    第十三届浙江省大学生程序设计竞赛 I 题, 一道模拟题. ZOJ  3944http://www.icpc.moe/onlinejudge/showProblem.do?problemCode=394 ...

  9. ZOJ 3686 A Simple Tree Problem

    A Simple Tree Problem Time Limit: 3 Seconds      Memory Limit: 65536 KB Given a rooted tree, each no ...

随机推荐

  1. hdu4135 Co-prime【容斥原理】

    Co-prime Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S ...

  2. 《TCP/IP详解卷1:协议》——第1章:概述(转载)

    1.引言 很多不同的厂家生产各种型号的计算机,它们运行完全不同的操作系统,但TCP/IP协议族允许它们互相进行通信.TCP/IP起源于60年代末美国政府资助的一个分组交换网络研究项目,到90年代已发展 ...

  3. msp430入门编程24

    msp430中C语言的扩展--段的使用 msp430入门学习 msp430入门编程

  4. java 字节码 指令集

    有时候为了能理解JVM对程序所做的优化等,需要查看程序的字节码,因此知道了解一些常见的指令集很重要! 指令码 助记符 说明 0x00 nop 什么都不做 0x01 aconst_null 将null推 ...

  5. poj2186 求有向图G中所有点都能到达的点的数量

    /*题意:有向图,求这样的点的数量:所有点都能到达它.缩点成有向无环图,思:如果该强连通有出度,那么 从该出度出去的边必然回不来(已经缩点了),所以有出度的强连通必然不是.那么是不是所有出度为0的强连 ...

  6. [Bzoj1009][HNOI2008]GT考试(KMP)(矩乘优化DP)

    1009: [HNOI2008]GT考试 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 4309  Solved: 2640[Submit][Statu ...

  7. hdu6080(最小环)

    题目 http://acm.hdu.edu.cn/showproblem.php?pid=6080 分析 很妙的思路,将里面的点集当作A,将外面的点集当作B 然后O(n^2)枚举两两B点,设一个是u, ...

  8. hdu 4057 Rescue the Rabbit

    题意 给出n(n<=10)个串,每个串有个权值,然后让你构造一个长度为l(l<=100)的串,如果他包含给出的串就得到相应的权值,求可能得到的最大权值 解法 AC自动机+DP,很显然要建立 ...

  9. javascript 自定义错误处理

    php 中是可以自定义程序的错误和异常处理函数的(handler).于是,我在想,javascript 中是否也存在和PHP中一样的异常和错误处理函数呢? try{}catch(){} 这种捕捉异常和 ...

  10. [Angular] Refactor Angular Component State Logic into Directives

    Allow the base toggle to be a tag (<toggle>) or attribute (<div toggle>). The <toggle ...