题目链接

题意:帮助joe走出一个大火蔓延的迷宫,其中joe每分钟可往上下左右四个方向之一走,所有着火的格子都会蔓延(空格与着火格有公共边,下一分钟这个空格也会着火)。迷宫中有一些障碍格,joe和火都无法进入,当joe走到一个边界的格子我们认为他走出了迷宫

输出R行C列的迷宫,#表示墙,.表示空地,J表示joe,F是着火格

如果能走出,输出最少时间否则,impossible

分析:不知道怎么处理大火蔓延这个东西,看了书上的方法,太棒了,就是对所以得着火点进行以bfs,就可以求出到蔓延到每一个格子的时间了,然后joe走的时候就看看他到这个格子的时候,时间到没到火蔓延的时候

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <queue>
using namespace std;
const int INF = 0x3f3f3f3f;
const int Max = + ;
int fire[Max][Max],g[Max][Max],vis[Max][Max];
int R,C;
int sx, sy;
int gx[] = {, , , -};
int gy[] = {-, , , };
int Time;
struct Node
{
int x,y;
};
queue<Node> Fire;
void solve(int i, int j, char ch)
{
if(ch == '#')
{
g[i][j] = -;
vis[i][j] = INF;
fire[i][j] = INF;
}
else if(ch == '.')
{
g[i][j] = ;
vis[i][j] = INF;
fire[i][j] = INF;
}
else if(ch == 'J')
{
sx = i;
sy = j;
vis[i][j] = ;
fire[i][j] = INF;
}
else if(ch == 'F')
{
fire[i][j] = ;
vis[i][j] = INF;
g[i][j] = ;
Node node;
node.x = i;
node.y = j;
Fire.push(node);
}
}
void fire_bfs() // 对大火蔓延的bfs
{
while(!Fire.empty())
{
Node node = Fire.front();
Fire.pop();
for(int i = ; i < ; i++)
{
int fx = node.x + gx[i];
int fy = node.y + gy[i];
if(fx >= && fx <= R && fy >= && fy <= C && g[fx][fy] != -)
{
if(fire[fx][fy] > fire[node.x][node.y] + )
{
fire[fx][fy] = fire[node.x][node.y] + ;
Node temp;
temp.x = fx;
temp.y = fy;
Fire.push(temp);
}
}
}
}
}
void road_bfs()
{
queue<Node> Road;
Node node;
node.x = sx;
node.y = sy;
Road.push(node);
while(!Road.empty())
{
node = Road.front();
Road.pop();
if(node.x == || node.x == R || node.y == || node.y == C)
{
Time = vis[node.x][node.y];
return;
}
for(int i = ; i < ; i++)
{
int fx = node.x + gx[i];
int fy = node.y + gy[i];
if(fx >= && fy >= && fx <= R && fy <= C && g[fx][fy] != -)
{
if(vis[fx][fy] > vis[node.x][node.y] + && vis[node.x][node.y] + < fire[fx][fy])
{
vis[fx][fy] = vis[node.x][node.y] + ;
Node temp;
temp.x = fx;
temp.y = fy;
Road.push(temp);
}
}
}
}
}
int main(int argc, char** argv)
{
int test;
scanf("%d", &test);
while (test--)
{
while(!Fire.empty())
Fire.pop();
scanf("%d%d", &R, &C);
getchar();
char ch;
for(int i = ; i <= R; i++)
{
for(int j = ; j <= C; j++)
{
scanf("%c", &ch);
solve(i, j, ch);
}
getchar();
}
Time = INF;
fire_bfs();
road_bfs();
if(Time != INF)
printf("%d\n", Time + );
else
printf("IMPOSSIBLE\n"); }
return ;
}

UVA11624Fire!(BFS)的更多相关文章

  1. 图的遍历(搜索)算法(深度优先算法DFS和广度优先算法BFS)

    图的遍历的定义: 从图的某个顶点出发访问遍图中所有顶点,且每个顶点仅被访问一次.(连通图与非连通图) 深度优先遍历(DFS): 1.访问指定的起始顶点: 2.若当前访问的顶点的邻接顶点有未被访问的,则 ...

  2. 【BZOJ-1656】The Grove 树木 BFS + 射线法

    1656: [Usaco2006 Jan] The Grove 树木 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 186  Solved: 118[Su ...

  3. POJ 3278 Catch That Cow(bfs)

    传送门 Catch That Cow Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 80273   Accepted: 25 ...

  4. POJ 2251 Dungeon Master(3D迷宫 bfs)

    传送门 Dungeon Master Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 28416   Accepted: 11 ...

  5. Sicily 1215: 脱离地牢(BFS)

    这道题按照题意直接BFS即可,主要要注意题意中的相遇是指两种情况:一种是同时到达同一格子,另一种是在移动时相遇,如Paris在(1,2),而Helen在(1,2),若下一步Paris到达(1,1),而 ...

  6. Sicily 1048: Inverso(BFS)

    题意是给出一个3*3的黑白网格,每点击其中一格就会使某些格子的颜色发生转变,求达到目标状态网格的操作.可用BFS搜索解答,用vector储存每次的操作 #include<bits/stdc++. ...

  7. Sicily 1444: Prime Path(BFS)

    题意为给出两个四位素数A.B,每次只能对A的某一位数字进行修改,使它成为另一个四位的素数,问最少经过多少操作,能使A变到B.可以直接进行BFS搜索 #include<bits/stdc++.h& ...

  8. Sicily 1051: 魔板(BFS+排重)

    相对1150题来说,这道题的N可能超过10,所以需要进行排重,即相同状态的魔板不要重复压倒队列里,这里我用map储存操作过的状态,也可以用康托编码来储存状态,这样时间缩短为0.03秒.关于康托展开可以 ...

  9. Sicily 1150: 简单魔板(BFS)

    此题可以使用BFS进行解答,使用8位的十进制数来储存魔板的状态,用BFS进行搜索即可 #include <bits/stdc++.h> using namespace std; int o ...

随机推荐

  1. Android音频播放之SoundPool

    SoundPool 一.基本概念 在Android应用程序的开发过程中,经常需要播放多媒体文件,也许最先想到的会是MediaPlayer类了,该类提供了播放.暂停.停止及重复播放等功能性方法(该类位于 ...

  2. coursera 公开课 文本挖掘和分析(text mining and analytics) week 1 笔记

    一.课程简介: text mining and analytics 是一门在coursera上的公开课,由美国伊利诺伊大学香槟分校(UIUC)计算机系教授 chengxiang zhai 讲授,公开课 ...

  3. 东大OJ-麦森数

    1064: 麦森数 时间限制: 1 Sec  内存限制: 128 MB 提交: 52  解决: 9 [提交][状态][讨论版] 题目描述 形如2P-1的素数称为麦森数,这时P一定也是个素数.但反过来不 ...

  4. mysql的sql_mode合理设置

    mysql的sql_mode合理设置 sql_mode是个很容易被忽视的变量,默认值是空值,在这种设置下是可以允许一些非法操作的,比如允许一些非法数据的插入.在生产环境必须将这个值设置为严格模式,所以 ...

  5. java 计算地球上两点间距离

    /** * 计算地球上任意两点(经纬度)距离 * * @param long1 * 第一点经度 * @param lat1 * 第一点纬度 * @param long2 * 第二点经度 * @para ...

  6. px和em和rem的区别

    一.px特点: 1. IE无法调整那些使用px作为单位的字体大小: 2. 国外的大部分网站能够调整的原因在于其使用了em或rem作为字体单位: 3. Firefox能够调整px和em,rem,但是96 ...

  7. SharedPrefernces使用实例讲解

    activity_main.xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android&qu ...

  8. Java微信公众号开发-外网映射工具配置

    一.开发环境准备 1.一个微信公众号 2.外网映射工具(开发调试)如花生壳.ngrok工具 注:与微信对接的URL要具备以下条件a:在公网上能够访问 b:端口只支持80端口 这里使用ngrok.cc: ...

  9. 转自文翼的博客:将本地时间转换为 GMT 时间

    在写 RSS 订阅接口的时候,发现最终输出文章的 RSS 时间(GMT时间),在本地上显示的时间和在服务器上显示的时间不一致. 原因是时区不一致,那么在 JavaScript 中,如何将时间转换为统一 ...

  10. 【USACO 2.2】Runaround Numbers

    找出第一个大于n的数满足:每一位上的数都不同,且没有0,第一位开始每次前进当前这位上的数那么多位,超过总位数就回到开头继续往前进,最后能不能每个位都到过一次且回到第一位,$n<10^9$. 暴力 ...