洛谷 P3395 路障 题解

news/2026/1/25 21:52:45/文章来源:https://www.cnblogs.com/CodingJuRuo/p/19530571

题目链接

洛谷 P3395 路障

思路分析

一道迷宫类问题,但不同的是它的障碍物的出现是在一既定时间往后。即对于位于 \(x_i,y_i\) 的障碍物 \(i\),它会在第 \(i\) 秒末尾开始出现,即\(i+1\) 秒后的移动都需要考虑它

我们就定义 \(mp_{i,j}\) 数组,一开始全部赋极大值 0x3f3f3f3f,对于障碍物 \(p\)\(mp_{x_p,y_p}=p\),即存储出现在哪一秒末尾。而对于移动来说,若第 \(q\) 秒到达,则 \(mp_{i,j}=-q\),即到达时间倒数。

所以当可以在第 \(q\) 秒到达时,若 \(q\le mp_{x_p,y_p}\),即还无需考虑这个障碍物,就按空格处理;否则则按障碍物处理。

代码如下,时间复杂度 \(O(Tn^2)\),注意由于总共有 \(2n-2\) 秒,所以要开两倍的数组存储。

代码呈现

#include<bits/stdc++.h>
using namespace std;
typedef pair<int,int> pii;const int N=1010;
int t,n;
int x[N*2],y[N*2],mp[N][N],dx[]={0,1,-1,0,0},dy[]={0,0,0,1,-1};void bfs(){queue<pii> q;q.push({1,1}),mp[1][1]=0;while (!q.empty()){pii u=q.front();q.pop();for (int i=1;i<=4;++i){int nx=u.first+dx[i],ny=u.second+dy[i],ns=-mp[u.first][u.second]+1; // 原本 mp[u.first][u.second] 存的是负值if (nx>=1 && nx<=n && ny>=1 && ny<=n && ns<=mp[nx][ny])mp[nx][ny]=-ns,q.push({nx,ny});}}
}
int main(){scanf("%d",&t);while (t--){scanf("%d",&n);for (int i=1;i<=2*(n-1);++i) scanf("%d%d",x+i,y+i);memset(mp,0x3f,sizeof mp); // 多测不清空for (int i=1;i<=2*(n-1);++i) mp[x[i]][y[i]]=i;bfs();printf(mp[n][n]<=0?"Yes\n":"No\n"); // <=0 表示能到达}return 0;
}

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

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

相关文章

实用指南:第七十五篇: 数据可视化(一):Matplotlib基础绘图与样式配置

实用指南:第七十五篇: 数据可视化(一):Matplotlib基础绘图与样式配置2026-01-25 21:48 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: …

讲解得物月付分期购额度怎么回收变现出来

得物月付额度:解锁潮流消费新方式,灵活购物更随心 在潮流消费成为年轻人生活日常的当下,得物作为潮流好物聚集地,为满足消费者灵活的购物需求,推出了得物月付这一专属消费信贷服务。专属的月付额度,搭配便捷的申…

26年寒假生活指导1.25

🎯 问题描述 在 Windows 环境下启动 Nacos 3.1.1 时遇到错误: PS D:\jslh2\jslh-cloud\nacos3.1.1\bin> ./startup.cmd -m standalone "nacos is starting with standalone" Error: Unable to access …

如何通过市场数据 API 计算 RSI、MACD 与移动平均线MA

通过市场iTick API获取金融数据并用Python计算RSI、MACD和移动平均线等核心技术指标,能有效帮助交易者识别趋势和动量。环境准备涉及安装Python库与设置API请求头,而数据获取需根据标的代码、市场和K线周期等参数。计…

Python Dash数据分析实战

你想知道如何用Python Dash把数据分析和可视化结合起来,搭建出交互式的分析应用,核心是想掌握从数据处理到可视化展示、再到交互逻辑实现的完整流程。下面我会从实操角度,一步步教你用Dash完成数据分析与可视化的全…

解读大数据领域数据中台的价值与意义

解读大数据领域数据中台的价值与意义&#xff1a;从“数据孤岛”到“数据中枢”的进化 一、引言&#xff1a;为什么数据中台成为企业的“必选项”&#xff1f; 在数字经济时代&#xff0c;数据被称为“新石油”&#xff0c;但现实中很多企业面临着“有数据无价值”的困境&…

深入了解大数据领域Hive的HQL语言特性

深入了解大数据领域Hive的HQL语言特性 关键词&#xff1a;Hive、HQL、大数据查询、分区表、元数据、MapReduce、UDF 摘要&#xff1a;本文将带你像拆积木一样拆解大数据领域的“查询利器”HiveQL&#xff08;简称HQL&#xff09;。我们会从HQL的诞生背景讲起&#xff0c;用“图…

【BUG】【Python】【爬虫】爬取加载中的数据

示例网页链接&#xff1a;https://movie.douban.com/subject/36907263/ BUG 浏览器开发者模式可以看到所需信息有对应的HTML显式结构 但代码爬取时发现结构被hidden&#xff0c;需要二次加载 import requestsurl https://movie.douban.com/subject/36907263/ headers {Us…

【BUG】【Python】清除字符串空格问题

BUG strip()后依旧有空格DEBUG strip()只清除字符串前后的包括空格、制表符、换行符等&#xff09;&#xff0c;中间的不处理。这时使用replace即可

ParseNet: LOOKING WIDER TO SEE BETTER——拓宽视野以更好地理解 - 实践

ParseNet: LOOKING WIDER TO SEE BETTER——拓宽视野以更好地理解 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family:…

Python Dash 快速搭建交互式Web应用

Dash 是 Plotly 公司推出的一款基于 Python 的低代码 Web 开发框架,无需前端(HTML/CSS/JavaScript)基础,就能快速构建高颜值、交互式的数据可视化 Web 应用。本文从环境搭建到实战案例,全程手把手教学,适合Pytho…

22-5. PLC的程序控制指令(子程序)

22-5. PLC的程序控制指令&#xff08;子程序&#xff09;在 PLC&#xff08;可编程逻辑控制器&#xff09;编程中&#xff0c;子程序指令是一种用于结构化编程的核心指令。它的核心思想是“模块化”&#xff1a;将复杂的程序分解成若干个独立的功能块&#xff0c;按需调用。简单…

先过滤后关联的优化经验分享

1、问题语句 最近遇到一个问题&#xff0c;发现开发人员比较喜欢单一的将表放一块一起做关联。如果有了先过滤后关联的思维&#xff0c;大部分语句的性能会获得提升。 以下是真实项目简化而来的例子 select * from ( select a.c1, a.mid, a.bcode,c.ttime ,row_number()over( p…

【视觉大模型论文精读】带你逐段解析 (持续更新)——总览

【视觉大模型论文精读】带你逐段解析 (持续更新)——总览 &#xff08;2021&#xff09;&#xff08;DINO&#xff09;Emerging Properties in Self-Supervised Vision Transformers论文精读&#xff08;逐段解析&#xff09; &#xff08;2023&#xff09;&#xff08;SAM&a…

「LUCKY STUN穿透」使用UptimeRobot使UPnP映射的TCP规则保持活跃

「LUCKY STUN穿透」使用UptimeRobot使UPnP映射的TCP规则保持活跃「LUCKY STUN穿透」使用UptimeRobot使UPnP映射的TCP规则保持活跃 2024.05.04 在之前的教程中我们通过UPnP映射 webhook等功能配合STUN穿透 实现了在无IP…

AI应用架构师详解:智能供应链预测系统模型服务化设计(TensorFlow Serving实践)

AI应用架构师详解:智能供应链预测系统的模型服务化设计——基于TensorFlow Serving的实践指南 一、引言:从"模型训练完成"到"生产可用"的最后一公里痛 作为AI应用架构师,我曾遇到过这样的场景: 数据科学家花了3个月训练出一个供应链销量预测模型——…

A. Perfect Root

time limit per test1 secondmemory limit per test256 megabytesA positive integer x is a perfect root if there exists an integer y such that y√x. For example, 5 is a perfect root because 25−−√5.For each test case, output n distinct perfect roots. Note th…

曲线Curve

曲线Curve1.setFromPoints .setFromPoints()是几何体BufferGeometry的一个方法,通过该方法可以把数组pointsArr中坐标数据提取出来赋值给几何体。具体说就是把pointsArr里面坐标数据提取出来,赋值给geometry.attribu…

「LUCKY STUN穿透」在Docker中使用MiniUPnP为BT客户端自动添加内外端口不同的映射规则

「LUCKY STUN穿透」在Docker中使用MiniUPnP为BT客户端自动添加内外端口不同的映射规则「LUCKY STUN穿透」在Docker中使用MiniUPnP为BT客户端自动添加内外端口不同的映射规则 2024.04.23 关于本教程 在之前的教程中我们…

【论文学习】重新审视面向持续图像分割的基于查询的 Transformer || 用于二分类图像分割的多视图聚合网络

Rethinking Query-based Transformer for Continual Image Segmentation 重新审视面向持续图像分割的基于查询的 Transformer 理解 针对 “持续图像分割” 任务&#xff0c;重新分析并优化 “基于查询的 Transformer” 模型的应用逻辑 基于查询的 Transformer&#xff1a;图…