Problem 2124 吃豆人

Accept: 134    Submit: 575

Time Limit: 1000 mSec    Memory Limit : 32768 KB

 Problem Description

吃豆人是一款很经典的游戏,游戏中玩家控制吃豆人在地图上吃光全部豆子,而且避免被怪物抓住。

这道题没有怪物,将游戏的画面分成n*m的格子,每格地形可能为空地或者障碍物。吃豆人能够在空地上移动,吃豆人每移动一格须要1s时间,而且仅仅能朝上下左右四个方向移动,特别的是吃豆人还能吐出舌头,舌头每移动一格须要0.1s时间,舌头仅仅能够走直线。

不必考虑吃豆人转身所须要的时间。

举例,吃豆人在(1,1)坐标。而豆子在(1,5)坐标。而且中间没有障碍物。此时朝豆子方向吐舌头~。经过0.8s就能够吃到豆子(来回各0.4s,吐出去的舌头要缩回来的嘛)。

游戏中还有加速道具,一旦得到加速道具,吃豆人就获得2倍移动速度,吐舌头的速度没有添加。即走1格用0.5s。如今地图上有且仅仅有一颗豆子。游戏中有.代表空地;X表示障碍。吃豆人不能越过障碍;B代表豆子。S代表加速道具,而且地图上道具总数不超过1个。道具所在的位置为空地,得到道具后马上使用。道具马上消失,地形变为空地,不能用舌头去取道具;P表示吃豆人,吐舌头的时候吃豆人不能移动。

 Input

输入包括多组数据。输入第一行有两个个整数n,m(2<=n,m<=20)。接着一个n*m的地图矩阵。

对于50%的数据,地图上没有道具。

 Output

输出一行,最快用多少s吃到豆子,结果保留1位小数,假设吃不到,输出-1。

 Sample Input

2 2XPB.3 2XP.SB.

 Sample Output

1.21.7

WA了非常多发,WA了非常多发,WA了非常多发。。。。

。。。

。。。。。。。

最開始的思路加上了优先队列。最先找到B的输出。非常多非常多例子非常多非常多例子非常多非常多例子都过了。我自己也拍了两个多小时的各种数据。。。

。。。。

。。。。。。

可是要知道优先队列优先的是当前走的时间,没有全局优先。又由于图不大,直接爆搜就可以。搜到一次B就记录一次答案。取最小。

总结一下这个题的解题注意的点:

0、注意vis数组要开成三维的vis【i】【x】【y】(vis【2】【x】【y】)i表示有无加速道具,0表示没有时候的情况,1表示有加速道具的情况。

至于为什么开成三维数组,小伙伴们能够细致考虑考虑。

1、爆搜是最好的思路。不要想一些花花绿绿的思路。

2、由于伸舌头比走的快,所以我们一定是用舌头吃到的B。

3、注意边界的处理。

AC思路:

对伸舌头部分的特殊处理:

                if(now.x==ex||now.y==ey)//假设当前的坐标是在B的同行或者同列
{
if(now.x==ex)//tonghang
{
int xx=now.x;
int yy=now.y;
int cont=0;
while(1)//向右伸舌头
{
yy+=1;
if(yy>=0&&yy<m)
{
cont++;
if(a[xx][yy]=='B')
{
if(now.output+cont*0.1*2<ans)//假设找到了一次B,那么记录一下
{
ans=now.output+cont*0.1*2;
break;
}
}
if(a[xx][yy]=='X')break;
}
else break;
}
cont=0;
yy=now.y;
while(1)//向左伸舌头
{
yy-=1;
if(yy>=0&&yy<m)
{
cont++;
if(a[xx][yy]=='B')
{
if(now.output+cont*0.1*2<ans)
{
ans=now.output+cont*0.1*2;
break;
}
}
if(a[xx][yy]=='X')break;
}
else break;
}
}
if(now.y==ey)//tonglie
{
int xx=now.x;
int yy=now.y;
int cont=0;
while(1)//向下伸舌头
{
xx+=1;
if(xx>=0&&xx<n)
{
cont++;
if(a[xx][yy]=='B')
{
if(now.output+cont*0.1*2<ans)
{
ans=now.output+cont*0.1*2;
break;
}
}
if(a[xx][yy]=='X')break;
}
else break;
}
cont=0;
xx=now.x;
while(1)//向上伸舌头
{
xx-=1;
if(xx>=0&&xx<n)//bug1
{
cont++;
if(a[xx][yy]=='B')
{
if(now.output+cont*0.1*2<ans)
{
ans=now.output+cont*0.1*2;
break;
}
}
if(a[xx][yy]=='X')break;
}
else break;
}
}
}

AC代码:

#include<stdio.h>
#include<queue>
#include<algorithm>
#include<string.h>
using namespace std;
struct zuobiao
{
int x,y;
float output;
int flag;
}now,nex;
int n,m;
char a[25][25];
int vis[2][25][25];
int fx[4]={0,0,1,-1};
int fy[4]={1,-1,0,0};
int sx,sy,ex,ey;
float ans;
void bfs(int x,int y)
{
memset(vis,0,sizeof(vis));
vis[0][x][y]=1;
now.x=x;now.y=y;now.output=0;now.flag=0;
queue<zuobiao >s;
s.push(now);
while(!s.empty())
{
now=s.front();
s.pop();
for(int i=-1;i<4;i++)
{
if(i==-1)
{
if(now.x==ex||now.y==ey)
{
if(now.x==ex)//tonghang
{
int xx=now.x;
int yy=now.y;
int cont=0;
while(1)
{
yy+=1;
if(yy>=0&&yy<m)
{
cont++;
if(a[xx][yy]=='B')
{
if(now.output+cont*0.1*2<ans)
{
ans=now.output+cont*0.1*2;
break;
}
}
if(a[xx][yy]=='X')break;
}
else break;
}
cont=0;
yy=now.y;
while(1)
{
yy-=1;
if(yy>=0&&yy<m)
{
cont++;
if(a[xx][yy]=='B')
{
if(now.output+cont*0.1*2<ans)
{
ans=now.output+cont*0.1*2;
break;
}
}
if(a[xx][yy]=='X')break;
}
else break;
}
}
if(now.y==ey)
{
int xx=now.x;
int yy=now.y;
int cont=0;
while(1)
{
xx+=1;
if(xx>=0&&xx<n)
{
cont++;
if(a[xx][yy]=='B')
{
if(now.output+cont*0.1*2<ans)
{
ans=now.output+cont*0.1*2;
break;
}
}
if(a[xx][yy]=='X')break;
}
else break;
}
cont=0;
xx=now.x;
while(1)
{
xx-=1;
if(xx>=0&&xx<n)//bug1
{
cont++;
if(a[xx][yy]=='B')
{
if(now.output+cont*0.1*2<ans)
{
ans=now.output+cont*0.1*2;
break;
}
}
if(a[xx][yy]=='X')break;
}
else break;
}
}
}
}
if(i==-1)continue;
nex.x=now.x+fx[i];
nex.y=now.y+fy[i];
nex.flag=now.flag;
if(nex.flag==0)//假设没有加速道具
nex.output=now.output+1;
if(nex.flag==1)//假设有加速道具
nex.output=now.output+0.5;
if(nex.x>=0&&nex.x<n&&nex.y>=0&&nex.y<m&&vis[nex.flag][nex.x][nex.y]==0&&a[nex.x][nex.y]!='X')
{
if(a[nex.x][nex.y]=='S')//吃到了加速道具
{
nex.flag=1;
s.push(nex);
vis[nex.flag][nex.x][nex.y]=1;
}
else//走到了空地
{
s.push(nex);
vis[nex.flag][nex.x][nex.y]=1;
}
}
}
}
}
int main()
{
while(~scanf("%d%d",&n,&m))
{
for(int i=0;i<n;i++)
{
scanf("%s",a[i]);
for(int j=0;j<m;j++)
{
if(a[i][j]=='P')
{
sx=i;
sy=j;
}
if(a[i][j]=='B')
{
ex=i;
ey=j;
}
}
}
ans=0x1f1f1f1f;
bfs(sx,sy);
if(ans==0x1f1f1f1f)printf("-1\n");
else
printf("%.1f\n",ans);
}
}

FZU 2124 FOJ 2124 吃豆人【BFS】的更多相关文章

  1. FZU 2124 吃豆人 bfs

    题目链接:吃豆人 比赛的时候写的bfs,纠结要不要有vis数组设置已被访问,没有的话死循环,有的话就不一定是最优解了.[此时先到的不一定就是时间最短的.]于是换dfs,WA. 赛后写了个炒鸡聪明的df ...

  2. Fzu2124 - 吃豆人 BFS

    Description 吃豆人是一款非常经典的游戏,游戏中玩家控制吃豆人在地图上吃光所有豆子,并且避免被怪物抓住. 这道题没有怪物,将游戏的画面分成n*m的格子,每格地形可能为空地或者障碍物,吃豆人可 ...

  3. TurnipBit开发板DIY呼吸的吃豆人教程实例

    转载请以链接形式注明文章来源(MicroPythonQQ技术交流群:157816561,公众号:MicroPython玩家汇) 0x00前言 吃豆人是耳熟能详的可爱形象,如今我们的TurnipBit也 ...

  4. [代码]解析nodejs的require,吃豆人的故事

    最近在项目中需要对nodejs的require关键字做解析,并且替换require里的路径.一开始我希望nodejs既然作为脚本语言,内核提供一个官方的parser库应该是一个稳定可靠又灵活的渠道,然 ...

  5. Unity项目 - 吃豆人Pacman

    项目展示 Github项目地址:Pacman 涉及知识 切片制作 Animations 状态机设置,any state切换,重写状态机 按键读取进行整数距离的刚体移动 用射线检测碰撞性 渲染顺序问题 ...

  6. 利用纯css写三角形,弧度箭头,吃豆人,气泡。放大镜,标签的源码

    1. 向上三角形

  7. css吃豆人动画

    一. Css吃豆人动画 1. 上半圆:两个div,内部一个圆div,外部设置宽高截取半圆 外部div动画:animation: 动画样式 1s(时长) ease(动画先低速后快速) infinite( ...

  8. 用python的turtle作图(二)动画吃豆人

    本文是用python的turtle作图的第二篇,通过这个例子可以了解动画的原理,用python自带的turtle库制作一些小动画. 1.问题描述 在上一篇"用python的turtle作图( ...

  9. Pac-Man 吃豆人

    发售年份 1980 平台 街机 开发商 南梦宫(Namco) 类型 迷宫 https://www.youtube.com/watch?v=dScq4P5gn4A

随机推荐

  1. 简单解决 ATL:CString WTL:CString 冲突

    //stdafx.h #include <atlbase.h> #include <atlstr.h> #include <atlapp.h> extern CAp ...

  2. Python之数据结构:字典

    key值需要是不可变对象,字典没有顺序 1.声明一个字典 dictA={ } 2.字典添加元素 dictA['name']='jack' dictA['age']=19 dictA['sex']='m ...

  3. 设置Animation 的播放位置

    AnimationState.normalizedTime 官方文档的描述 Description The normalized time of the animation. A value of 1 ...

  4. 向量内积(bzoj 3243)

    Description 两个d 维向量A=[a1,a2,...,ad]与B=[b1,b2,...,bd]的内积为其相对应维度的权值的乘积和,即: 现有 n 个d 维向量x1,...,xn ,小喵喵想知 ...

  5. dva脚手架 dva-cli 配置roadhogrc,antd-mobile样式按需加载 不生效的问题

    1.新安装dva-cli脚手架版本0.9.2,dva版本是2.4.1,roadhogrc版本是2.4.9 roadhogrc2 与1 的区别把roadhogrc 改成了webpackrc 所以配置an ...

  6. Codeforces Round #454 Div. 2 A B C (暂时)

    A. Masha and bears 题意 人的体积为\(V\),车的大小为\(size\),人能钻进车的条件是\(V\leq size\),人对车满意的条件是\(2V\geq size\). 现知道 ...

  7. GDB 命令详细解释

    Linux中包含有一个很有用的调试工具--gdb(GNU Debuger),它可以用来调试C和C++程序,功能不亚于Windows下的许多图形界面的调试工具. 和所有常用的调试工具一样,gdb提供了以 ...

  8. Scrapy笔记:使用scrapy shell url时出现403错误的解决办法

    参考 : http://www.th7.cn/Program/Python/201704/1154208.shtml 原因是网站的防爬虫配置起到了作用 (1):第一种方法是在命令上加上-s USER_ ...

  9. yii框架美化访问路径,去掉index.php/?r=部分

    一.找到配置文件(ps:advance高级模板) 在工程目录-> backend目录 或 frontend目录 -> config目录 -> main.php文件 -> 在 r ...

  10. MySQL 手动主从同步不锁表

    有时候MySQL主从同步不一致比较严重的时候,需要手动同步. 然而网上看大很多需要锁表的同步的方法基本如下 1.先对主库锁表 FLUSH TABLES WITH READ LOCK; 2.备份数据 m ...