#include<stdio.h>

#include<queue>

#include<math.h>

#include<algorithm>

#include<iostream>

#include<string.h>

using namespace std;

#define N 30

char map[N][N];

struct node {

double t;

int x,y,f;

friend bool operator<(node a,node b) {

           return a.t>b.t;

}

};

double  min(double a,double b) {

return a>b?b:a;

}

double max(double a,double b) {

return a>b?a:b;

}

int px,py,bx,by,n,m,visit[N][N],visits[N][N];

int dis[4][2]={1,0,-1,0,0,1,0,-1};

double ans;

int judge(int x,int y) {

 if(x>=1&&x<=n&&y>=1&&y<=m&&map[x][y]!='X')

return 1;

 return 0;

}

void bfs() {

   int i,tstart,tend;

   memset(visit,0,sizeof(visit));

   memset(visits,0,sizeof(visits));//第二个数组用来记录获得加速器后的状态情况

   priority_queue<node>q;

   node cur,next;

   cur.x=px;cur.y=py;

   cur.t=0;

   cur.f=0;

   visit[px][py]=1;

   q.push(cur);

   while(!q.empty()) {//对时间用优先队列

    cur=q.top();

q.pop();

if(cur.x==bx)  {//

tstart=min(cur.y,by);

tend=max(cur.y,by);

for(i=tstart;i<=tend;i++) 

 if(map[cur.x][i]=='X')

 break;

 if(i==tend+1) 

 ans=min(ans,(tend-tstart)*0.2+cur.t);

}

if(cur.y==by) {//判断伸舌头是否能吃掉

    tstart=min(cur.x,bx);

tend=max(cur.x,bx);

for(i=tstart;i<=tend;i++) 

if(map[i][cur.y]=='X')

break;

if(i==tend+1) 

 ans=min(ans,(tend-tstart)*0.2+cur.t);



for(i=0;i<4;i++) {

      int  x=next.x=cur.x+dis[i][0];

 int y=next.y=cur.y+dis[i][1];

 if(judge(x,y)) {

 if(cur.f==0&&visit[x][y])continue;//

 if(cur.f&&visits[x][y])continue;//有一个不符合就跳过

 if(x==bx&&y==by) {//出口

              ans=min(ans,cur.t+0.2);

 printf("%.1f\n",ans);

 return ;

 }

 if(cur.f==1) {

          next.t=cur.t+0.5;

          next.f=1;

 }

          else {

     next.t=cur.t+1;

 next.f=0;

 }

 if(map[x][y]=='S') {

             next.f=1;

map[x][y]='.';

 }

if(next.f==1)

visits[x][y]=1;

else

visit[x][y]=1;

 q.push(next);

 }

}

   }

   printf("-1\n");

   return ;

}

int main() {

int i,j;

while(scanf("%d%d",&n,&m)!=EOF) {

          for(i=1;i<=n;i++)

 scanf("%s",map[i]+1);

 for(i=1;i<=n;i++) 

 for(j=1;j<=m;j++) {

             if(map[i][j]=='P') 

px=i,py=j;

if(map[i][j]=='B')

bx=i,by=j;

 }

ans=999999999;

         bfs();

}

return 0;

}

fzu 2124的更多相关文章

  1. FZU 2124 FOJ 2124 吃豆人【BFS】

     Problem 2124 吃豆人 Accept: 134    Submit: 575 Time Limit: 1000 mSec    Memory Limit : 32768 KB  Probl ...

  2. FZU 2124 bfs+vis记录

    第一次团队训练赛的题 自己看完题没看到不能用舌头吃道具..以为是什么贪心混合bfs..果断放弃..悄悄的背锅了 然后其实比较简单 只是利用vis记录的时候要分两种状态记录 有没有道具 每到一个地方 就 ...

  3. FZU 2124 吃豆人 bfs

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

  4. FZU 2137 奇异字符串 后缀树组+RMQ

    题目连接:http://acm.fzu.edu.cn/problem.php?pid=2137 题解: 枚举x位置,向左右延伸计算答案 如何计算答案:对字符串建立SA,那么对于想双延伸的长度L,假如有 ...

  5. FZU 1914 单调队列

    题目链接:http://acm.fzu.edu.cn/problem.php?pid=1914 题意: 给出一个数列,如果它的前i(1<=i<=n)项和都是正的,那么这个数列是正的,问这个 ...

  6. ACM: FZU 2105 Digits Count - 位运算的线段树【黑科技福利】

     FZU 2105  Digits Count Time Limit:10000MS     Memory Limit:262144KB     64bit IO Format:%I64d & ...

  7. FZU 2112 并查集、欧拉通路

    原题:http://acm.fzu.edu.cn/problem.php?pid=2112 首先是,票上没有提到的点是不需要去的. 然后我们先考虑这个图有几个连通分量,我们可以用一个并查集来维护,假设 ...

  8. ACM: FZU 2107 Hua Rong Dao - DFS - 暴力

    FZU 2107 Hua Rong Dao Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I6 ...

  9. ACM: FZU 2112 Tickets - 欧拉回路 - 并查集

     FZU 2112 Tickets Time Limit:3000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u P ...

随机推荐

  1. POJ 1056 IMMEDIATE DECODABILITY Trie 字符串前缀查找

    POJ1056 给定若干个字符串的集合 判断每个集合中是否有某个字符串是其他某个字符串的前缀 (哈夫曼编码有这个要求) 简单的过一遍Trie就可以了 #include<iostream> ...

  2. Mac 终端执行JavaScript

    创建: 2017/09/16    第一步   打开命令  输入alias jsc="/System/Library/Frameworks/JavaScriptCore.framework/ ...

  3. [App Store Connect帮助]三、管理 App 和版本(5)添加平台以创建通用购买

    您可以为 App 添加一个平台以创建通用购买.例如,为现有的 iOS App 添加相关的 Apple TVOS App,从而将该 Apple TVOS App 和 iOS App 一同出售. 与创建新 ...

  4. unittest举例

    步骤:1.先导入unittest2.编写一个测试类(继承unittest.TestCase)3.编写测试用例类,一个方法就是一条用例4.加载测试用例,有三种方式:加载测试方法,加载测试类,加载测试模块 ...

  5. mysql select 操作优先级

    单表查询操作 select filed1,filed2... form table where ... group by ... having .... order by ... limit ... ...

  6. Mac OS下配置 ADB环境变量

    前提已经安装了Android sdk. 步骤打开终端Terminal, 输入open -e ~/.bash_profile, 若之前没有该文件,会自动创建.添加内容 export PATH=${PAT ...

  7. NS2学习笔记(二)

    Tcl语言 变量和变量赋值 set a "Hello World!" #将字符串赋值给变量a puts "NS2 say $a" #输出字符串的内容,其中$a表 ...

  8. 【CodeForces727E/CF727E】Games on a CD (字符串哈希)

    题目: CodeForces727E 分析: 看到字符串比较,肯定想到哈希啊--现学的哈希,先丢两个重要的公式 (\(seed\)是大于字符集大小的质数,\(p\)是大质数) \[hash[i]=(h ...

  9. org.eclipse.jdt.internal.compiler.classfmt.ClassFormatException。

    jdk1.8环境tomcat运行项目报错, org.eclipse.jdt.internal.compiler.classfmt.ClassFormatException.解决方法:更改jdk1.7

  10. 笨拙而诡异的 Oracle(之二)

    有一张表,很多数据:   想取某个月的数据.初始的想法很简单,根据日期(RQ)形成条件即可:  符合条件的记录数是 129835,但耗时太长:14.515 秒(RQ字段是做过索引的)!直观的反应是 O ...