题目:

乔在迷宫中工作。不幸的是,迷宫的一部分着火了,迷宫的主人没有制定火灾的逃跑计划。请帮助乔逃离迷宫。根据乔在迷宫中的位置以及迷宫的哪个方块着火,你必须确定火焰烧到他之前,乔是否可以离开迷宫,如果能离开他能跑多快。
乔和火每分钟移动一个方格,上、下、左、右,四个方向中的一个。火势向四个方向同时蔓延。乔可以从迷宫的任何一个边界逃离迷宫。无论是乔还是火都不会到达有墙的位置。

输入:

第一行输入包含一个整数,即测试次数
每个测试用例的第一行包含两个
整数R和C,用空格分隔,1≤R,C≤1000
下面R行中,每一行都包含C个字符,以及每个字符是以下之一:
# 代表墙
. 代表空地,火和乔是可通行的
J 乔在迷宫中最初的位置,火和乔是可通行的
F 代表火
在每组测试中只有一个J

输出:

对于每个测试用例,如果在火蔓延的时候烧到了乔,则乔无法逃出迷宫,输出'IMPOSSIBLE'如果乔能逃出迷宫,则输出乔最快可以在几分钟内安全逃出迷宫,每组输出占一行

样例:

分析:因为火出现位置传播方向固定,所以何时何地会被火覆盖是固定的,只要先进行预处理得到某处在几分钟后会被大火覆盖,在进行BFS时经过某点时间小于这个时间就ok了,同时如果该点不会被大火覆盖那它对应的临界时间就是INF

  1 #include<iostream>
  2 #include<sstream>
  3 #include<cstdio>
  4 #include<cstdlib>
  5 #include<string>
  6 #include<cstring>
  7 #include<algorithm>
  8 #include<functional>
  9 #include<iomanip>
 10 #include<numeric>
 11 #include<cmath>
 12 #include<queue>
 13 #include<vector>
 14 #include<set>
 15 #include<cctype>
 16 #define PI acos(-1.0)
 17 const int INF = 0x3f3f3f3f;
 18 const int NINF = -INF - 1;
 19 typedef long long ll;
 20 using namespace std;
 21 int n, m, flag;
 22 char maze[1005][1005];//迷宫
 23 typedef pair<int, int> P;
 24 int usedf[1005][1005], usedj[1005][1005];//火; 人 是否经过
 25 int d[1005][1005], tim[1005][1005];//人;火 时间
 26 int st, ed;//起点
 27 int dx[4] = {1, 0, -1, 0}, dy[4] = {0, 1, 0, -1};
 28 queue<P> fire;
 29 void ini()//预处理大火覆盖所需时间(BFS)
 30 {
 31     while (fire.size())
 32     {
 33         P rec = fire.front();
 34         fire.pop();
 35         for (int i = 0; i < 4; ++i)
 36         {
 37             int nx = rec.first + dx[i], ny = rec.second + dy[i];
 38             if (nx >= 0 && nx < n && ny >= 0 && ny < m && !usedf[nx][ny] && maze[nx][ny] != '#')
 39             {
 40                 usedf[nx][ny] = 1;
 41                 fire.push(P(nx, ny));
 42                 tim[nx][ny] = tim[rec.first][rec.second] + 1;
 43             }
 44         }
 45     }
 46 }
 47 int bfs()
 48 {
 49     queue<P> q;
 50     memset(usedj, 0, sizeof(usedj));
 51     for (int i = 0; i < n; ++i)
 52     {
 53         for (int j = 0; j < m; ++j)
 54             d[i][j] = INF;
 55     }
 56     q.push(P(st, ed));
 57     usedj[st][ed] = 1;
 58     d[st][ed] = 0;
 59     P temp;
 60     while(q.size())
 61     {
 62         temp = q.front();
 63         q.pop();
 64         if (temp.first == 0 || temp.first == n - 1 || temp.second == 0 || temp.second == m - 1)//到达边界即逃出
 65         {
 66             flag = 1;
 67             break;
 68         }
 69         for (int i = 0; i < 4; ++i)
 70         {
 71             int nx = temp.first + dx[i], ny = temp.second + dy[i];
 72             if (nx >= 0 && nx < n && ny >= 0 && ny < m && !usedj[nx][ny] && maze[nx][ny] == '.' && d[temp.first][temp.second] + 1 < tim[nx][ny])
 73             {
 74                 usedj[nx][ny] = 1;
 75                 q.push(P(nx, ny));
 76                 d[nx][ny] = d[temp.first][temp.second] + 1;
 77             }
 78         }
 79     }
 80     if (flag) return d[temp.first][temp.second] + 1;
 81     else return -1;
 82 }
 83 int main()
 84 {
 85     int T;
 86     cin >> T;
 87     while (T--)
 88     {
 89         flag = 0;
 90         cin >> n >> m;
 91         memset(usedf, 0, sizeof(usedf));//预处理的BFS函数的初始化,写在这里方便输入时给特殊位置赋值
 92         for (int i = 0; i < n; ++i)
 93         {
 94             for (int j = 0; j < m; ++j)
 95                 tim[i][j] = INF;
 96         }
 97         for (int i = 0; i < n; ++i)
 98         {
 99             for (int j = 0; j < m; ++j)
100             {
101                 cin >> maze[i][j];
102                 if (maze[i][j] == 'J')  st = i, ed = j;
103                 if (maze[i][j] == 'F')
104                 {
105                     usedf[i][j] = 1;
106                     tim[i][j] = 0;
107                     fire.push(P(i, j));
108                 }
109             }
110         }
111         ini();
112         int ans = bfs();
113         if (ans != -1) cout << ans << endl;
114         else cout << "IMPOSSIBLE" << endl;
115         while(fire.size()) fire.pop();
116     }
117     return 0;
118 }

转载于:https://www.cnblogs.com/veasky/p/10975520.html

UVA11624 Fire!相关推荐

  1. UVA11624 Fire!(bfs)

    相信大家已经读过题目了,我就搬一下洛谷的翻译: 题目大意 你的任务是帮助Joe走出一个大火蔓延的迷宫.Joe每分钟可以走到上下左右4个方向的相邻格子之一,而所有着火的格子都会四周蔓延(即如果某个空格子 ...

  2. kuangbin 专题一 简单搜索

    kuangbin 专题一 简单搜索 1.POJ1321棋盘问题[DFS] 代码 自己的想法 2.POJ2251Dungeon Master[三维空间BFS] 代码 自己的想法 3.POJ3278 Ca ...

  3. 搜索专题(不定期更新)

    1.POJ 2386  Lake Counting 题意:给出一块区域,询问有多少个湖泊? 思路:DFS,对于'W',深搜一次,并标记已访问.之后每次对未访问的'W'做一次深搜. 1 #include ...

  4. fzu 2150 Fire Game 【身手BFS】

    称号:fzu 2150 Fire Game :给出一个m*n的图,'#'表示草坪,' . '表示空地,然后能够选择在随意的两个草坪格子点火.火每 1 s会向周围四个格子扩散,问选择那两个点使得燃烧全部 ...

  5. fire.php,Fire PHP

    项目介绍: Fire PHP 是基于 PHP JavaScript开发的跨平台的Firefox 的扩充套件,即PHP调试插件,可以帮你debug 后端PHP 的程式,其使用的技术跟某些IDE 一样,要 ...

  6. ZOJ1002 Fire Net(非递归版)

    以前用递归的回溯搜索思路做过一次,参见ZOJ1002 Fire Net(递归版),今天想着用非递归的方法试试看,呵呵,比我想象中要难啊,主要还是堆栈里究竟放什么,这一点上思路一直没理清.因此用了整整一 ...

  7. J - Fire! UVA - 11624

    J - Fire! UVA - 11624 题意:火每次能烧到上下左右,人碰到非墙的边界则逃火成功,求最短的逃离时间. 由于bfs每个位置最多入队出队一次,所以复杂度为 1e6 一发bfs直接TLE, ...

  8. 1709: Fire or Retreat(zzuli)

    水题,哎,可是第一次是因为编译错了,vs不知咋了,无奈: 后面几次又因为类型用了int错了,痛苦: 题目描述 在与科技水平远胜于我们的外星人的战斗最后,我们能够用来对外星装甲造成伤害的武器只剩下了-- ...

  9. xmpp 服务器配置 open fire for windows 及 spark 测试

    xmpp 服务器配置 open fire for windows 此文章为 XMPP windows服务器配置,使用的是 open fire 3.9.1.exe 1: 下载 open fire ope ...

最新文章

  1. 机器人攻牙_惠东攻牙机
  2. java 正方形字符串_java编程:怎么画一个正方形?
  3. MySQL-binlog格式对主从复制的影响MySQL主从复制的过程
  4. 纯JDBC系统的开发随想
  5. sparkshelljarlib_Spark应用程序第三方jar文件依赖解决方案
  6. PHP的的指针的特性
  7. java jtree 监听_Java JTree.addTreeExpansionListener方法代码示例
  8. python︱函数、for、if、_name_、迭代器、防范报错、类定义、装饰器、argparse模块、yield
  9. 查询-非等值连接,外连接,子查询
  10. 外卖返利cps小程序path
  11. [CSP-S模拟测试]:走格子(模拟+BFS+Dijkstra)
  12. Windows安全更新出现0x800f081f错误解决方案
  13. javascript网页设计期末作业 购物网站
  14. android看黑白电子书软件,如何优雅解决App启动黑白屏
  15. 等比序列的实际应用 —等额本息还款金额公式推导
  16. 自媒体必备工具:免费的音文对齐生成SRT字幕,快速打轴匹配声音及文字的在线工具
  17. python自动生成字幕_深度学习实现自动生成图片字幕
  18. OSChina 周一乱弹 —— 济南源创会特刊
  19. 浏览器打不开服务器网页,浏览器打不开某几个网页,这样来解决
  20. 大素数判定以及大整数分解

热门文章

  1. MSM--Memcached_Session_Manager介绍及使用
  2. 怎样不让Dreamweaver中HTML源代码不自动换行??
  3. Spring3.1.2与Hibernate4.1.8整合
  4. Android中启动Activity(startActivity)流程图分析
  5. Android自定义控件(四)仿网易客户端上拉加载更多
  6. c++ 大数类 大数模板
  7. 史上最详细最容易理解的HMM文章
  8. Java转型(向上或向下转型)
  9. Go中的Socket编程
  10. 取MySQL最后几行数据