bfs P2895 [USACO08FEB] Meteor Shower S

[P2895 USACO08FEB] Meteor Shower S - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

bfs。难点在于处理走到该点时的时间与该处陨石降落的时间的比较。

可以发现,在某处可能有多个陨石降落,但是此题只考虑陨石降落的最小时间。因此,我们可以考虑根据陨石的降落位置和时间,对陨石降落地进行预处理,取最小时间。在此,将二维空间初始化为 I N F INF INF,因为题目保证了 T i ≤ 1000 T_i \le 1000 Ti1000,因此等于 I N F INF INF的位置一定是没有陨石降落的。根据读入的陨石位置和时间预处理出该处陨石降落的最小时间。

之后进行bfs,在搜到的位置 x , y x,y x,y处,如果 p h x , y = I N F ph_{x,y} = INF phx,y=INF,表明该处一定没有陨石降落,输出即可。否则,需要判断该处合法:没有超界,没有访问过,到此处的时间大于该处陨石降落的时间。

坑点可能还在于:陨石降落是在 [ 0 , 300 ] [0, 300] [0,300]之间的,但是人是可以走到300之外的位置的。

代码如下:

namespace direction {
namespace d8 {
vector<int> fx({0, 0, 1, 1, 1, -1, -1, -1}), fy({1, -1, 1, 0, -1, 1, 0, -1});
}
namespace d4 {
vector<int> fx({0,0,1,-1}), fy({1,-1,0,0});
}
}
using namespace::direction::d4;void inpfile();
void solve() {  int n; cin>>n;vector<vector<int>> ph(310, vector<int> (310, INF));vector<vector<int>> vis(310, vector<int>(310));for(int i = 0; i < n; ++i) {int x,y,t; cin>>x>>y>>t;// 预处理陨石位置附近的最小时间ph[x][y] = min(ph[x][y], t);for(int j = 0; j < 4; ++j) {int xx = x + fx[j], yy = y + fy[j];// 只用考虑小于0的情况,大于300的不用考虑。因为是陨石下降在[0, 300] 但是人是可以走到300之外的if(xx < 0 || yy < 0) continue;ph[xx][yy] = min(ph[xx][yy], t);}}queue<array<int,3>> q; // x, y, cnt;vis[0][0] = 1;q.push({0, 0, 0});while(q.size()) {auto tmp = q.front(); q.pop();int x = tmp[0], y = tmp[1], cnt = tmp[2] + 1;// 如果当前位置是INF,表示没有陨石会降落,输出返回即可if(ph[x][y] == INF) {cout<<cnt - 1<<endl;return ;}// 否则该处会用陨石降落,不是安全的地方for(int i = 0; i < 4; ++i) {int xx = x + fx[i], yy = y + fy[i];// 此时需要判断边界,虽然人是可以超出300的,但是显然303要比300003要优,// 如果在此不进行判断,则可能会死循环,RE,CE等if(xx < 0 || xx > 303 || yy < 0 || yy > 303) continue;// 之前走过if(vis[xx][yy]) continue;// 走到此时,该处就已经有陨石降落if(ph[xx][yy] <= cnt) continue;vis[xx][yy] = 1;q.push({xx, yy, cnt}); }}cout<<-1<<endl;
} 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/197279.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

测试:JMeter和LoadRunner比较

比较 JMeter和LoadRunner是两款常用的软件性能测试工具&#xff0c;它们在功能和性能上有一定的相似性和差异。下面从几个方面对它们进行比较&#xff1a; 1. 架构和原理&#xff1a; JMeter和LoadRunner的架构和原理基本相同&#xff0c;都是通过中间代理监控和收集并发客户…

软件测试【理论基础】

软件测试的IEEE定义&#xff1a;使用人工或自动的手段来运行或测量软件系统的过程&#xff0c;目的是检验软件系统是否满足规定的需求&#xff0c;并找出与预期结果之间的差异。 软件测试的发展趋势&#xff1a; ① 测试工作将进一步前移。软件测试不仅仅是单元测试、集成测…

数据结构算法-插入排序算法

引言 玩纸牌 的时候。往往 需要将牌从乱序排列变成有序排列 这就是插入排序 插入排序算法思想 先看图 首先第一个元素 我默认已有序 那我们从第二个元素开始&#xff0c;依次插入到前面已有序的部分中。具体来说&#xff0c;我们将第二个元素与第一个元素比较&#xff0c;…

软件工程 单选多选补充 复刻

原文 软件的主要特性&#xff1a;无形、高成本、包括程序和文档 软件工程三要素&#xff1a;方法、工具、过程 螺旋模型包含风险分析 软件工程的主要目标&#xff1a;风险分析 面向对象开发&#xff1a;Booch、UML、Coad、OMT 软件危机的主要表现&#xff1a;软件成本太高…

单细胞测序并不一定需要harmony去除批次效应

大家好&#xff0c;今天我们分享的是单细胞的学习教程https://www.singlecellworkshop.com/analysis-tutorial.html 教程的作者使用了四个样本&#xff0c;但是没有使用harmony或者其他方法去整合 去除批次效应。 主要内容&#xff1a; SCTransform流程代码及结果 harmony流程…

Shell脚本介绍

Shell脚本是一种使用文本编辑器编写的简单脚本语言&#xff0c;它可以自动化常见的系统任务&#xff0c;例如执行命令、处理文件和文本数据等。Shell脚本通常使用Unix或Linux系统中的shell&#xff08;例如bash&#xff09;来解释执行。 Shell脚本的基本语法包括&#xff1a; …

scrapy的建模及管道的使用

一、数据建模 通常在做项目的过程中&#xff0c;在items.py中进行数据建模 为什么建模 定义item即提前规划好哪些字段需要抓&#xff0c;防止手误&#xff0c;因为定义好之后&#xff0c;在运行过程中&#xff0c;系统会自动检查&#xff0c;配合注释一起可以清晰的知道要抓…

【面试经典150 | 二叉树】二叉树的最大深度

文章目录 写在前面Tag题目来源解题思路方法一&#xff1a;递归方法二&#xff1a;迭代 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法&#xff0c;两到三天更新一篇文章&#xff0c;欢迎催更…… 专栏内容以分析题目为主&#xff0c;并附带一些对于本题涉及到的…

MVSNeRF:多视图立体视觉的快速推广辐射场重建

MVSNeRF&#xff1a;多视图立体视觉的快速推广辐射场重建 摘要1 引言 摘要 在2021年&#xff0c;作者提出了MVSNeRF&#xff0c;一种新的神经渲染方法&#xff0c;在视图合成中可以有效地重建神经辐射场。与之前对神经辐射场的研究不同&#xff0c;我们考虑了对密集捕获的图像…

十分钟带你看懂——Python测试框架之pytest最全讲

pytest特短 pytest是一个非常成熟的全功能的Python测试框架&#xff0c;主要有以下几个特点&#xff1a; 简单灵活&#xff0c;容易上手 支持参数化 能够支持简单的单元测试和复杂的功能测试&#xff0c;还可以用来做selenium/appnium等自动化测试、接口自动化测试&#xff08…

C++获取当前exe或者 dll所在的路径,并读取配置文件

目录 一、C获取当前动态库所在的路径两种方式&#xff1a; 1、使用操作系统相关的API来实现 2、利用GetModuleFileNameA 二、读取配置文件 1、先了解下GetPrivateProfileString 读取配置信息 2、读取配置信息示例说明&#xff1a; 3、梳理集中类型获取值的示例 一、C获取…

如何能够对使用ShaderGraph开发的Shader使用SetTextureOffset和SetTextureScale方法

假设在ShaderGraph中的纹理的引用名称为"_BaseMap"&#xff0c;同时对这个"_BaseMap"纹理使用了采样的节点"SampleTexture2D"&#xff0c;然后该采样节点的uv接入的TilingAndOffset节点&#xff0c;此时的关键步骤是新建一个Vector4属性&#xf…

mac如何永久设置环境变量

1. 先将默认shell修改为bash mac修改默认shell为bash-CSDN博客 2. 修改环境变量 Mac中的环境变量介绍 Mac系统的环境变量&#xff0c;加载顺序为&#xff1a; /etc/profile /etc/paths ~/.bash_profile ~/.bash_login ~/.profile ~/.bashrc 当然/etc/profile和/etc/paths…

C++实现顺序栈的基本操作(扩展)

#include <stdio.h> typedef char ElemType; #define StackSize 100 /*顺序栈的初始分配空间*/ typedef struct { ElemType data[StackSize]; /*保存栈中元素*/int top; /*栈顶指针*/ } SqStack; void InitStack(SqStack &st) {st.top-1; } …

SSM整合(注解版)

SSM 整合是指将学习的 Spring&#xff0c;SpringMVC&#xff0c;MyBatis 进行整合&#xff0c;来进行项目的开发。 1 项目基本的配置类 1.1 Spring 配置类 这个配置类主要是管理 Service 中的 bean&#xff0c;controller 层的 bean 对象是 SpringMVC 管理的 package cn.ed…

案例研究|作为一家BI厂商,飞致云是如何人人使用DataEase的?

杭州飞致云信息科技有限公司&#xff08;以下简称为飞致云&#xff09;长期秉持“软件用起来才有价值&#xff0c;才有改进的机会”的核心价值观&#xff0c;以“为数字经济时代创造好软件”为使命&#xff0c;致力于成为中国数字化团队首选的通用工具软件提供商。在软件产品不…

编码器-解码器(seq-seq)

1. 背景 encoder-decoder和seq-seq模型可以解决输入与输出都是不定长序列的问题。它们都用到了两个循环NN&#xff0c;分别叫做编码器(用来分析输入序列)与解码器(用来生成输出序列)。 2. 编码器 把一个不定长的输入序列变换成一个定长的背景变量c&#xff0c;并在其中编码输入…

【文心一言实践】使用文心一言创建MYSQL表及实体模型和Mapper

本来想写一个Spring Batch 线程池使用不当形成死锁的代码案例&#xff0c;但是需要建一张表还要初始化大量数据&#xff0c;这时想起了文心一言&#xff0c;试用了一下&#xff0c;确实大幅提升了效率。 以下是使用文心一言编码构建表和实体和DAO层接口的实践&#xff1a; 问&…

大文件分片上传、分片进度以及整体进度、断点续传【前端原生、后端 Koa、Node 原生】(一)

分片&#xff08;500MB&#xff09;进度效果展示 效果展示&#xff0c;一个分片是 500MB 的 分片&#xff08;10MB&#xff09;进度效果展示 大文件分片上传效果展示 前端 思路 前端的思路&#xff1a;将大文件切分成多个小文件&#xff0c;然后并发给后端。 页面构建 先在页…

算法通关村——海量数据处理办法

从40个亿中产生一个不存在的整数 题目&#xff1a;给定一个输入文件&#xff0c;包含40亿个非负整数&#xff0c;请设计一个算法&#xff0c;产生一个不存在该文件中的整数&#xff0c;假设你由1GB的内存来完成任务。 用位图去存储大数据 在数据量很大时&#xff0c;采用位方…