FZU 2124 FOJ 2124 吃豆人【BFS】
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
Sample Input
Sample Output
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】的更多相关文章
- FZU 2124 吃豆人 bfs
题目链接:吃豆人 比赛的时候写的bfs,纠结要不要有vis数组设置已被访问,没有的话死循环,有的话就不一定是最优解了.[此时先到的不一定就是时间最短的.]于是换dfs,WA. 赛后写了个炒鸡聪明的df ...
- Fzu2124 - 吃豆人 BFS
Description 吃豆人是一款非常经典的游戏,游戏中玩家控制吃豆人在地图上吃光所有豆子,并且避免被怪物抓住. 这道题没有怪物,将游戏的画面分成n*m的格子,每格地形可能为空地或者障碍物,吃豆人可 ...
- TurnipBit开发板DIY呼吸的吃豆人教程实例
转载请以链接形式注明文章来源(MicroPythonQQ技术交流群:157816561,公众号:MicroPython玩家汇) 0x00前言 吃豆人是耳熟能详的可爱形象,如今我们的TurnipBit也 ...
- [代码]解析nodejs的require,吃豆人的故事
最近在项目中需要对nodejs的require关键字做解析,并且替换require里的路径.一开始我希望nodejs既然作为脚本语言,内核提供一个官方的parser库应该是一个稳定可靠又灵活的渠道,然 ...
- Unity项目 - 吃豆人Pacman
项目展示 Github项目地址:Pacman 涉及知识 切片制作 Animations 状态机设置,any state切换,重写状态机 按键读取进行整数距离的刚体移动 用射线检测碰撞性 渲染顺序问题 ...
- 利用纯css写三角形,弧度箭头,吃豆人,气泡。放大镜,标签的源码
1. 向上三角形
- css吃豆人动画
一. Css吃豆人动画 1. 上半圆:两个div,内部一个圆div,外部设置宽高截取半圆 外部div动画:animation: 动画样式 1s(时长) ease(动画先低速后快速) infinite( ...
- 用python的turtle作图(二)动画吃豆人
本文是用python的turtle作图的第二篇,通过这个例子可以了解动画的原理,用python自带的turtle库制作一些小动画. 1.问题描述 在上一篇"用python的turtle作图( ...
- Pac-Man 吃豆人
发售年份 1980 平台 街机 开发商 南梦宫(Namco) 类型 迷宫 https://www.youtube.com/watch?v=dScq4P5gn4A
随机推荐
- hdu 1025 n*logn最长上升子序列
/* TLE */ #include <iostream> #include <cstdio> #include <cstring> using namespace ...
- javascript提示框,随着鼠标移动
原文发布时间为:2009-04-23 -- 来源于本人的百度文章 [由搬家工具导入] <html><script type="text/javascript"&g ...
- web.config add handlers and httpmodule to System.Web section.
<?xml version="1.0" encoding="utf-8"?> <!-- For more information on how ...
- 转一个网址,canvas用法
http://blog.csdn.net/jia20003/article/details/9251893 http://www.w3school.com.cn/cssref/pr_animation ...
- Python学习杂记_6_字典常用操作
字典操作 字典是由一对花括号括起来的一组“键值对”,每个键值对就是字典的一个元素,元素在字典中是无序的,常见操作如下: info = { 'name':'xiaoming', 'sex':'nan', ...
- pyinstaller打包exe程序各种坑!!!
pyinstaller打包python成exe可执行程序,各种报错,各种坑,在次记录下 一.pyinstaller打包报错for real_module_name, six_moduleAttribu ...
- LeetCode OJ-- Maximal Rectangle ***@
https://oj.leetcode.com/problems/maximal-rectangle/ 给一个二维矩阵,里面只有0 1,求一个最大的矩阵,里面的所有元素都是1. 首先预处理: 0 1 ...
- LeetCode OJ--Palindrome Number
https://oj.leetcode.com/problems/palindrome-number/ 判断是否为回文数 取每一位存到vector中,再判断 负数不是回文数 class Solutio ...
- Android Studio查看其它APP的布局结构
概述 日常使用别家的APP过程中,会遇到一些比较好看的布局,这时候我们就想学习一下别人的布局结构,以便参考. (1)手机连接电脑.设置手机为USB调试模式 (2)运行Android Studio,打开 ...
- cocoapods集成三方库遇到的坑
什么都不想说直接上图 这是最近在管理三方库时遇到头疼的问题,刚开始一直怀疑是cocoapods或者ruby的版本问题但是升级到最新版还是同样的错误,后来又怀疑是资源文件的问题但是在同一时间不同地点集成 ...