与其说是训练不如说是重温。重新写了Java版本的代码。

import java.util.*;
import java.math.*;
import java.io.BufferedInputStream; public class Main
{
static class Node
{
int r, c, t;
public Node(int _r, int _c)
{
this(_r, _c, 0);
}
public Node(int _r, int _c, int _t)
{
r=_r; c=_c; t=_t;
}
} static int[][] fireTime = new int[1005][1005];
static int[][] maze = new int[1005][1005];
static Queue<Node> q = new LinkedList<>();
static final int[] dx = {0,1,0,-1};
static final int[] dy = {1,0,-1,0};
static int r, c;
static int startR, startC; static void getFireTime()
{
for(int i=0;i<=r;++i)
for(int j=0;j<=c;++j)
fireTime[i][j]=0x3f3f3f3f;
while(!q.isEmpty())
{
Node node = q.poll();
fireTime[node.r][node.c] = node.t;
for(int i=0; i!=4; ++i)
{
int tr = node.r + dx[i],
tc = node.c + dy[i];
if(tr>=0 && tr<r && tc>=0 && tc<c && fireTime[tr][tc]>node.t+1 && maze[tr][tc]==1)
{
fireTime[tr][tc] = node.t+1;
q.offer(new Node(tr, tc, node.t+1));
}
}
}
}
static String solve()
{
Queue<Node> sq = new LinkedList<>();
boolean[][] vis = new boolean[1005][1005];
sq.offer(new Node(startR, startC));
vis[startR][startC]=true;
while(!sq.isEmpty())
{
Node now = sq.poll();
if(now.t>=fireTime[now.r][now.c]) continue;
if(now.r==0 || now.r == r-1 || now.c == 0 || now.c == c-1)
return String.valueOf(now.t+1);
for(int i=0;i!=4;++i)
{
int tr = now.r + dx[i],
tc = now.c + dy[i]; if(tr>=0 && tr<r && tc>=0 && tc<c && fireTime[tr][tc]>now.t+1 && (!vis[tr][tc]) && maze[tr][tc]==1)
{
vis[tr][tc]=true;
sq.offer(new Node(tr, tc, now.t+1));
}
}
}
return "IMPOSSIBLE";
}
public static void main(String args[])
{
Scanner cin = new Scanner(new BufferedInputStream(System.in));
int T = cin.nextInt();
while(T-- != 0)
{
q.clear();
r = cin.nextInt();
c = cin.nextInt();
for(int i=0; i!=r; ++i)
{
String str = cin.next();
for(int j=0;j!=c;++j)
{
char chr = str.charAt(j);
if(chr == '#') maze[i][j] = 0;
else if(chr == '.') maze[i][j] = 1;
else if(chr == 'J')
{
maze[i][j] = 1;
startR=i; startC=j;
}
else if(chr == 'F')
{
maze[i][j] = 1;
q.offer(new Node(i,j));
}
}
}
getFireTime();
System.out.println(solve());
}
}
}

「日常训练」 Fire!(UVA-11624)的更多相关文章

  1. 「日常训练」ZgukistringZ(Codeforces Round #307 Div. 2 B)

    题意与分析(CodeForces 551B) 这他妈哪里是日常训练,这是日常弟中弟. 题意是这样的,给出一个字符串A,再给出两个字符串B,C,求A中任意量字符交换后(不限制次数)能够得到的使B,C作为 ...

  2. 「日常训练」COMMON 约数研究(HYSBZ-1968)

    题意与分析 感谢https://www.cnblogs.com/Leohh/p/7512960.html的题解.这题话说原来不在我的训练范围,正好有个同学问我,我就拿来做做.数学果然不是我擅长的啊,这 ...

  3. 「日常训练」 Mike and Fun (CFR305D2B)

    题意(CodeForces 548B) 每次对01矩阵中的一位取反,问每次操作后,单列中最长连续1的长度. 分析 非常非常简单,但是我当时训练的时候WA了四次...无力吐槽了,人间 不值得.jpg 代 ...

  4. 「日常训练」Common Subexpression Elimination(UVa-12219)

    今天做的题目就是抱佛脚2333 懂的都懂. 这条题目干了好几天,最后还是参考别人的代码敲出来了,但是自己独立思考了两天多,还是有收获的. 思路分析 做这条题我是先按照之前的那条题目(The SetSt ...

  5. 「日常训练」Magic Stones(CodeForces-1110E)

    题意 给定两个数组c和t,可以对c数组中的任何元素变换\(c_i\)​成\(c_{i+1}+c_{i-1}-c_i\)​,问c数组在若干次变换后能否变换成t数组. 分析 这种魔法题目我是同样的没做过. ...

  6. 「日常训练」Jongmah(Codeforces-1110D)

    题意 你有n个数字,范围[1, m],你可以选择其中的三个数字构成一个三元组,但是这三个数字必须是连续的或者相同的,每个数字只能用一次,问这n个数字最多构成多少个三元组? 分析 根据官方Editori ...

  7. 「日常训练」The Necklace(UVA-10054)

    代码 for(int i=0; i!=n; ++i) { int u = cin.nextInt(); int v = cin.nextInt(); edges.add(new Edge(u,v)); ...

  8. 「日常训练」Known Notation(ZOJ-3829)

    题意与分析 题意是这样的:给一个字符串,字符串中只包含数字和运算符'*'.现在问字符串是不是一个合法的逆波兰式(后缀表达式).已知逆波兰式的空格消除,也就是说123可以看成123也可以看成1和23.如 ...

  9. 「日常训练」 Genghis Khan the Conqueror(HDU-4126)

    题意 给定\(n\)个点和\(m\)条无向边(\(n\le 3000\)),需要将这\(n\)个点连通.但是有\(Q\)次(\(Q\le 10^4\))等概率的破坏,每次破坏会把\(m\)条边中的某条 ...

随机推荐

  1. 4、RabbitMQ-消息应答与消息持久化

    消息应答( Message acknowledgment) 1. Message acknowledgment(消息应答) 执行任务可能需要几秒钟.你可能想知道如果其中一个消费者开始一项长期任务并且只 ...

  2. Java8 Stream()关于在所有用户的所有上传记录中,找出每个用户最新上传记录

    原创文章:转载请标明出处 https://www.cnblogs.com/yunqing/p/9504196.html 首先分析相当于如下,在所有的猫中,每个名字的猫都保留年龄最小的一个 import ...

  3. C#网络Socket编程

    1.什么是Socket Sockets 是一种进程通信机制,是一个通信链的句柄(其实就是两个程序通信用的) 2.分类 流式套接字(SOCK_STREAM):提供了一种可靠的.面向连接的双向数据传输服务 ...

  4. 阅读 CloudDPI:Cloud+DPI+Reversible Sketch

    CloudDPI: Cloud-Based Privacy-Preserving Deep Packet Inspection via Reversible Sketch 与sketch的结合点:将修 ...

  5. Node.js 上传图片并保存

    Node.js 上传图片并保存 依赖 package.json 文件 { "name": "demo", "version": " ...

  6. Cache Buffer 区别

    Cache 一般位于CPU中, 分为 L1 Cache, L2 Cache, 是一种读的操作,把CPU刚用过的/循环使用的数据存储起来,当CPU再次使用时,可以直接从Cache存储器中调用,减少了等待 ...

  7. android学习:关于RelativeLayout叠放布局的问题

    RelativeLayout布局关于元素叠加的问题 1.RelativeLayout布局中的元素如果要实现元素叠加必须设置  RelativeLayout.ALIGN_PARENT_TOP  这样元素 ...

  8. ImageMagick使用小结

    #查看是否安装imagemagick sudo apt list | grep imagemagick #安装imagemagick sudo apt-get install imagemagick ...

  9. 撩妹技能 get,教你用 canvas 画一场流星雨

    开始 妹子都喜欢流星,如果她说不喜欢,那她一定是一个假妹子. 现在就一起来做一场流星雨,用程序员的野路子浪漫一下. 要画一场流星雨,首先,自然我们要会画一颗流星. 玩过 canvas 的同学,你画圆画 ...

  10. python基础知识你学会了多少

    前言 学习是一个循序渐进的过程,不在于你学了多少,而在于你学会了多少.(装个b好吧,hhhh) 知识总结 之前一直想在网上找一个总结好的笔记,但是一直都没有找到,因此下定决心要总结一下,里面的都是在学 ...