一起来看流星雨吧(话说我还没看到过流星雨呢)

题目

Problem

小A则听说另一个骇人听闻的消息: 一场流星雨即将袭击整个霸中,由于流星体积过大,它们无法在撞击到地面前燃烧殆尽,届时将会对它撞到的一切东西造成毁灭性的打击。

很自然地,小A开始担心自己的安全问题。他一定要在被流星砸到前,到达一个安全的地方(也就是说,一块不会被任何流星砸到的土地)。

如果将霸中放入一个直角坐标系中,小A现在的位置是原点,并且小A不能踏上一块被流星砸过的土地。根据预报,一共有M颗流星(1 \le M \le 50,0001≤M≤50,000)会坠落在霸中上,其中第i颗流星会在时刻 T_iT​i​​ (0 \le T_i \le 1,0000≤T​i​​≤1,000)砸在坐标为(X_i,Y_iX​i​​,Y​i​​) (0 \le X_i \le 3000≤X​i​​≤300;0 \le Y_i \le 3000≤Y​i​​≤300) 的格子里。

流星的力量会将它所在的格子,以及周围4个相邻的格子都化为焦土,当然小A也无法再在这些格子上行走。小A在时刻0开始行动,它只能在第一象限中, 平行于坐标轴行动,每1个时刻中,她能移动到相邻的(一般是4个)格子中的任意一个,当然目标格子要没有被烧焦才行。如果一个格子在时刻t被流星撞击或烧焦,那么小A只能在t之前的时刻在这个格子里出现。

请你计算一下,小A最少需要多少时间才能到达一个安全的格子。
注意土地的边界应该大于流星的边界,因为如果逃到那些地方也算安全地带。

Input Data

第1行: 1个正整数:MM 
第2..M+2..M+1行: 第i+1i+1行为3个用空格隔开的整数:X_iX​i​​,Y_iY​i​​,以及T_iT​i​​

Output Data

输出1个整数,即小A逃生所花的最少时间。如果小A无论如何都无法在流星雨中存活下来,输出-1

Input / Output Sample

 Input
4
0 0 2
2 1 2
1 1 2
0 3 5 Output
5

题目思路

一道搜索题,求最小步数最好用bfs, 要记录下每个区块被摧毁的时间,具体看代码

代码

#include <bits/stdc++.h>
using namespace std;
int n, t[1000][1000], inf, dx[4] = {1, 0, -1, 0}, dy[4] = {0, 1, 0, -1}, ans = 1e9;
bool vis[1000][1000];
struct node{int xx, yy, tt;};
void bfs (){
queue <node> q;
q.push((node){1, 1, 0});
while (q.size()){
node tmp = q.front(); q.pop();
for (int i = 0; i < 4; i++){
int tx = tmp.xx + dx[i], ty = tmp.yy + dy[i];
if (vis[tx][ty] or tx < 1 or tx > 302 or ty < 1 or ty > 302) continue;
//若越界就跳过, 注意:因为数据范围最大为300,所以上限计为302
if (t[tx][ty] <= tmp.tt + 1) continue;
if (t[tx][ty] == inf) {ans = tmp.tt + 1; return;} //t[tx][ty]为inf则是安全区
q.push((node){tx, ty, tmp.tt + 1});
vis[tx][ty] = 1;
}
}
}
int main(){
scanf ("%d", &n);
memset (t, 0x3f, sizeof (t)); inf = t[1][1]; //将毁坏时间初始化为最大值
for (int i = 1, x, y, ti; i <= n; i++){
scanf ("%d %d %d", &x, &y, &ti), x++, y++; //将坐标+1后可避免越界
t[x][y] = min (t[x][y], ti); //当同一块被多次砸毁时时间取 min
for (int i = 0; i < 4; i++) t[x+dx[i]][y+dy[i]] = min (t[x+dx[i]][y+dy[i]], ti);
}
bfs ();
if (ans == 1e9) ans = -1; //如果答案仍为最大值则无法走出, 计为-1;
printf ("%d", ans);
return 0;
}

  

点一下左边的推荐吧!谢谢~~~

洛谷 P2895 [USACO08FEB]流星雨Meteor Shower 解题报告的更多相关文章

  1. 洛谷—— P2895 [USACO08FEB]流星雨Meteor Shower

    P2895 [USACO08FEB]流星雨Meteor Shower 题目描述 Bessie hears that an extraordinary meteor shower is coming; ...

  2. 洛谷P2895 [USACO08FEB]流星雨Meteor Shower

    题目描述 Bessie hears that an extraordinary meteor shower is coming; reports say that these meteors will ...

  3. 洛谷 P2895 [USACO08FEB]流星雨Meteor Shower

    题目描述 Bessie hears that an extraordinary meteor shower is coming; reports say that these meteors will ...

  4. bzoj1611 / P2895 [USACO08FEB]流星雨Meteor Shower

    P2895 [USACO08FEB]流星雨Meteor Shower 给每个点标记一下能够走的最迟时间,蓝后bfs处理一下 #include<iostream> #include<c ...

  5. P2895 [USACO08FEB]流星雨Meteor Shower

    传送门 预处理出每个位置最早被摧毁的时间,在此之前都可以走 直接dfs加个记忆化和最优性剪枝就好了 一定要注意流星的边界,如果波及到负数坐标的位置不要去考虑会RE 一定要考虑流星砸到边界的情况 如 ( ...

  6. 洛谷 P2323 [HNOI2006]公路修建问题 解题报告

    P2323 [HNOI2006]公路修建问题 题目描述 输入输出格式 输入格式: 在实际评测时,将只会有m-1行公路 输出格式: 思路: 二分答案 然后把每条能加的大边都加上,然后加小边 但在洛谷的题 ...

  7. 洛谷 P2895 [USACO08FEB]Meteor Shower S (BFS)

    题意:你刚开始位于坐标轴的\((0,0)\)点,一共有\(m\)颗流星砸向地面,每颗流星在\(t\)时砸到\((x,y)\)点,其四周上下左右也均有波及,你每秒可以向上下左右移动一个单位,问你是否可以 ...

  8. 洛谷 P1852 [国家集训队]跳跳棋 解题报告

    P1852 [国家集训队]跳跳棋 题目描述 跳跳棋是在一条数轴上进行的.棋子只能摆在整点上.每个点不能摆超过一个棋子. 我们用跳跳棋来做一个简单的游戏:棋盘上有3颗棋子,分别在\(a\),\(b\), ...

  9. 洛谷 P3299 [SDOI2013]保护出题人 解题报告

    P3299 [SDOI2013]保护出题人 题目描述 出题人铭铭认为给SDOI2012出题太可怕了,因为总要被骂,于是他又给SDOI2013出题了. 参加SDOI2012的小朋友们释放出大量的僵尸,企 ...

随机推荐

  1. git用远程库的内容覆盖本地

    git fetch --all 下载远程的库的内容到本地,不做任何的合并(怎么合并可以自己选择) git reset --hard origin/master 撤销本地.暂存区.版本库(用远程服务器的 ...

  2. 主成分分析(PCA)与SVD奇异值分解

      主要参考:https://www.zhihu.com/question/38417101/answer/94338598 http://blog.jobbole.com/88208/ 先说下PCA ...

  3. Contiki源码结构

    Contiki源码结构 apps目录下,用于存放Application,也就是我们的应用程序放在这个目录下.如webserver,webrowser等,如下图所示. core目录是contiki操作系 ...

  4. LoadRunner监控图表与配置(一) 监控与图表

    1.“Monitoer”菜单-“Online Graphs”-“Open a new graph”打开监视图表列表. 实际上这些监视图表已经在Available Graphs中显示了出来. 2.常用监 ...

  5. 【boost】使用serialization库序列化子类

    boost.serialization库是一个非常强大又易用的序列化库,用于对象的保存与持久化等. 使用base_object可以在序列化子类的同时也序列化父类,以此获得足够的信息来从文件或网络数据中 ...

  6. OpenCV——PS 滤镜算法之平面坐标到极坐标的变换

    // define head function #ifndef PS_ALGORITHM_H_INCLUDED #define PS_ALGORITHM_H_INCLUDED #include < ...

  7. resEdit

    resEdit:一个图形界面编辑工具,它不但可以用来编写程序所图形界面(如修改图标.菜单.鼠标.版本信息等),还支持了对exe.dll等执行文件内的资源(图标.菜单.鼠标指针.位图.版本信息)等进行修 ...

  8. 结合Mysql和kettle邮件发送日常报表_20161001

    十一假期 参加婚礼 稍晚点发博 整体流程步骤是: 写SQL-导出到excel设定excel模板调整格式-设置kettle转换--设置kettle邮件作业--完成 第一.写SQL 保持最近12个周的数据 ...

  9. 【Lintcode】033.N-Queens

    题目: The n-queens puzzle is the problem of placing n queens on an n×n chessboard such that no two que ...

  10. 数据结构与算法(5)----->二叉树

    1.  概念 二叉树节点的结构: class Node{ int value; // value表示二叉树的节点值 Node left; Node right; // left和right表示二叉树的 ...