P1119 灾后重建【题解】

P1119 灾后重建

题目背景

B 地区在地震过后,所有村庄都造成了一定的损毁,而这场地震却没对公路造成什么影响。但是在村庄重建好之前,所有与未重建完成的村庄的公路均无法通车。换句话说,只有连接着两个重建完成的村庄的公路才能通车,只能到达重建完成的村庄。

题目描述

给出 B 地区的村庄数 NNN,村庄编号从 000N−1N-1N1,和所有 MMM 条公路的长度,公路是双向的。并给出第 iii 个村庄重建完成的时间 tit_iti,你可以认为是同时开始重建并在第 tit_iti 天重建完成,并且在当天即可通车。若 tit_iti000 则说明地震未对此地区造成损坏,一开始就可以通车。之后有 QQQ 个询问 (x,y,t)(x,y,t)(x,y,t),对于每个询问你要回答在第 ttt 天,从村庄 xxx 到村庄 yyy 的最短路径长度为多少。如果无法找到从 xxx 村庄到 yyy 村庄的路径,经过若干个已重建完成的村庄,或者村庄 xxx 或村庄 yyy 在第 ttt 天仍未重建完成,则需要输出 −1-11

输入格式

第一行包含两个正整数 N,MN,MN,M,表示了村庄的数目与公路的数量。

第二行包含 NNN 个非负整数 t0,t1,⋯ ,tN−1t_0,t_1,\cdots,t_{N-1}t0,t1,,tN1,表示了每个村庄重建完成的时间,数据保证了 t0≤t1≤⋯≤tN−1t_0 \le t_1 \le \cdots \le t_{N-1}t0t1tN1

接下来 MMM 行,每行 333 个非负整数 i,j,wi,j,wi,j,wwww 不超过 100001000010000,表示了有一条连接村庄 iii 与村庄 jjj 的道路,长度为 www,保证 i≠ji\neq ji=j,且对于任意一对村庄只会存在一条道路。

接下来一行也就是 M+3M+3M+3 行包含一个正整数 QQQ,表示 QQQ 个询问。

接下来 QQQ 行,每行 333 个非负整数 x,y,tx,y,tx,y,t,询问在第 ttt 天,从村庄 xxx 到村庄 yyy 的最短路径长度为多少,数据保证了 ttt 是不下降的。

输出格式

QQQ 行,对每一个询问 (x,y,t)(x,y,t)(x,y,t) 输出对应的答案,即在第 ttt 天,从村庄 xxx 到村庄 yyy 的最短路径长度为多少。如果在第 ttt 天无法找到从 xxx 村庄到 yyy 村庄的路径,经过若干个已重建完成的村庄,或者村庄 xxx 或村庄 yyy 在第 ttt 天仍未修复完成,则输出 −1-11

输入输出样例 #1

输入 #1

4 5
1 2 3 4
0 2 1
2 3 1
3 1 2
2 1 4
0 3 5
4
2 0 2
0 1 2
0 1 3
0 1 4

输出 #1

-1
-1
5
4

说明/提示

  • 对于 30%30\%30% 的数据,有 N≤50N\le 50N50
  • 对于 30%30\%30% 的数据,有 ti=0t_i=0ti=0,其中有 20%20\%20% 的数据有 ti=0t_i=0ti=0N>50N>50N>50
  • 对于 50%50\%50% 的数据,有 Q≤100Q\le 100Q100
  • 对于 100%100\%100% 的数据,有 1≤N≤2001\le N\le 2001N2000≤M≤N×(N−1)20\le M\le \dfrac{N\times(N-1)}{2}0M2N×(N1)1≤Q≤500001\le Q\le 500001Q50000,所有输入数据涉及整数均不超过 10510^5105

解析

观察题目,发现它要求任意两点间的最短距离,且数据具有 1≤N≤2001\le N\le 2001N200 的特点,数据很小。所以就想到最短路中的 FloyedFloyedFloyed 算法

FloyedFloyedFloyed 的基本逻辑就是,枚举中间点来确定每对终起点的最短距离。值得注意的是,每次枚举得到的结果是当前最优,但并不是最终答案。

而这道题目中,由于点的是否可用存在限制,所以我们可在枚举中间点时,留个心眼,每次查询的中间点都只枚举到可用点。

因为读题发现,村庄序号增加,修复时间也增加或不变,则只需判断在时间进一步放宽的情况下,在原基础下是否有新的村庄可修复。而且数据保证了 ttt 是不下降的,即每次访问,时间对于之前都是放宽或不变的。这大大方便了做题。

保留之前最短路结果仍然有用。在每次查询时,枚举所有新增的可用村庄作为中间点,算得每对村庄之间的最短路。不必担心某对终起点村庄未修复,因为在查询时再进行判断终起点是否修好,没修好就输出-1,修好就输出记录的最短值,在它们本身修好之前形成的最短路依旧存在啊。

代码

#include<bits/stdc++.h>
using namespace std;
int n,m,q,now;
int t[205];
int dist[205][205];
void build(int k){for(int i=0;i<n;i++){for(int j=0;j<n;j++){dist[i][j]=min(dist[i][j],dist[i][k]+dist[k][j]);//k作为中间点检查是否有最短路}}
}
int main(){cin>>n>>m;for(int i=0;i<n;i++){cin>>t[i];}/*初始化*/memset(dist,0x3f,sizeof dist);for(int i=0;i<n;i++){dist[i][i]=0;} for(int i=1;i<=m;i++){int x,y;cin>>x>>y;cin>>dist[x][y];dist[y][x]=dist[x][y];}//cin>>q;while(q--){int x,y,k;cin>>x>>y>>k;while(t[now]<=k&&now<n){//判断接下来的村庄是否已修复//因为序号增加,修复时间也增加或不变,则只需判断在时间进一步放宽的情况下,在原基础下是否有新的村庄可修复build(now);//加入新的中间点更新最短路now++;//判断下个村庄}if(k<t[x]||k<t[y]){//终起点未修复cout<<-1;}else{if(dist[x][y]==0x3f3f3f3f) cout<<-1;//没路else cout<<dist[x][y];//有最小值}cout<<endl;}return 0;
}

Thanks♪(・ω・)ノ for listening!Can you give me a 赞 QAQ?

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

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

相关文章

Horse3D引擎研发笔记(二):基于QtOpenGL使用仿Three.js的BufferAttribute结构重构三角形绘制

在Horse3D引擎的研发过程中&#xff0c;我们致力于构建一个高效、灵活且易于扩展的3D图形引擎。在本篇博客中&#xff0c;我们将详细记录如何基于QtOpenGL框架&#xff0c;使用仿Three.js的BufferAttribute结构&#xff0c;重构三角形绘制流程。通过这一过程&#xff0c;我们希…

MCU程序段的分类

程序的下载&#xff08;烧录到存储器中&#xff09;通常是按照程序文件分段&#xff08;Code段、RO_data段、RW_data段、ZI_data段&#xff09;的方式存储的&#xff0c;但运行时内存的布局会按照程序进程分段&#xff08;TEXT段、DATA段、BSS段、堆栈段&#xff09;进行组织。…

综合项目记录:自动化备份全网服务器数据平台

一、项目背景与需求1.1项目概述该项目共分为2个子项目&#xff0c;由环境搭建和实施备份两部分组成1.2项目总体需求企业内部有一台web服务器&#xff0c;内部数据很重要&#xff0c;现需要为该web服务器数据做备份&#xff0c;这样在数据丢失时可以恢复。要求如下&#xff1a;每…

联合索引全解析:一棵树,撑起查询的半边天

目录 一、为什么联合索引是MySQL性能优化的“王牌”&#xff1f; &#xff08;一&#xff09;索引的基本结构&#xff1a;从聚簇到非聚簇 1. 聚簇索引&#xff08;Clustered Index&#xff09; 2. 非聚簇索引&#xff08;Secondary Index&#xff09; &#xff08;二&…

vue开发的计算机课程页面

课程信息展示页面设计与实现我将设计一个美观且实用的课程信息展示页面&#xff0c;重点展示计算机网络应用课程的相关信息。设计思路使用卡片式布局清晰展示课程各模块信息采用科技感配色方案&#xff0c;符合计算机网络课程主题添加动画效果增强用户体验响应式设计确保在各种…

MySQL 正则表达式详细说明

目录 MySQL 正则表达式详细说明 1. 基本操作符&#xff1a;REGEXP 和 RLIKE 2. 常用正则表达式模式 3. MySQL 正则表达式函数&#xff08;MySQL 8.0&#xff09; 4. 示例查询 5. 注意事项 6. 总结 MySQL 正则表达式详细说明 MySQL 支持正则表达式&#xff08;Regular Ex…

c++之 栈浅析

C之栈浅析 概要 通过可视化游戏梳理栈特点以及栈操作方式. 学习栈的工作原理就像往糖果罐里放糖果和拿糖果一样简单&#xff01; 栈特点 先进后出 技术名词解释 LIFO LIFO -> Last In, First Out 后进先出 可视化小游戏 游戏传送门

C++ 算术函子

在 C 中&#xff0c;算术函子&#xff08;Arithmetic Functors&#xff09; 是标准库 <functional> 中提供的一组函数对象&#xff0c;用于封装基本的算术运算&#xff08;如加、减、乘、除等&#xff09;。它们本质上是类模板&#xff0c;重载了 operator()&#xff0c;…

Flutter 事件总线 Event Bus

文章目录概要核心原理基本使用步骤优点注意事项适用场景小结概要 提示&#xff1a;这里可以添加技术概要 event_bus 是一个常用的第三方库&#xff0c;用于实现跨组件 / 跨页面的事件通信&#xff0c;基于发布 - 订阅模式&#xff08;Publish-Subscribe Pattern&#xff09;工…

数据库管理系统:入门需要了解的内容

数据库管理系统&#xff1a;数字化时代的基石 在信息技术飞速发展的今天&#xff0c;我们生活在一个被数据包围的世界里。从日常使用的社交媒体、电商平台&#xff0c;到企业运营的核心业务系统&#xff0c;再到政府部门的政务管理&#xff0c;数据无处不在。而数据库管理系统&…

安装CST时,报错问题处理

今天安装这个软件的时候&#xff0c;发现一个问题一直处理不了&#xff0c;然后看网上的一些解决方法&#xff0c;最终得到处理&#xff0c;这里就简单记录下解决方法。问题&#xff1a;处理方案&#xff1a;1.问题原因&#xff1a;crack中的CST Studio Suite 2022未配置成功。…

分治-快排-215.数组中的第k个最大元素-力扣(LeetCode)

一、题目解析1、需返回排序好的第k个最大元素2、要求时间复杂度为O(N)二、算法原理解法1&#xff1a;堆排序(大根堆) k*O(N)借用大堆的性质&#xff0c;将元素插入到大堆中&#xff0c;按照k输出堆顶第k个元素解法2&#xff1a;堆排序(小根堆) (N-k)*O(logN)先建k个小堆&#x…

新手向:Python实现图片转ASCII艺术

Python实现图片转ASCII艺术&#xff1a;从零开始的完整指南Python实现图片转ASCII艺术的技术解析ASCII艺术是一种使用字符组合来表现图像的技术&#xff0c;这种技术源于早期计算机显示器的图形限制&#xff0c;如今已成为一种独特的数字艺术形式。ASCII艺术的应用场景十分广泛…

6.类与对象(二)

总结 本章写了封装、static成员以及代码块。 一、封装 1.封装的概念 封装简单来说就是被密封起来&#xff08;不让我们看见的东西&#xff09;&#xff0c;即被隐藏。 对于用户来说&#xff0c;并不需要关心的类&#xff0c;所实现的细节就会被封装&#xff08;隐藏&#x…

流形折叠与条件机制

1. 为什么要防止流形折叠&#xff08;mode collapse&#xff09; 流形折叠 生成器只学会输出极少数甚至单一模式&#xff08;mode&#xff09;的样本&#xff0c;而完全忽略数据分布的多样性。 后果一句话&#xff1a;“模型看起来生成了很多图&#xff0c;其实都在重复同一张…

《从零构建大语言模型》学习笔记2,文本数据处理1(以及tiktoken库无法下载gpt2参数,调用get_encoding时SSL超时的解决方法)

《从零构建大语言模型》学习笔记2&#xff0c;文本数据处理1 文章目录《从零构建大语言模型》学习笔记2&#xff0c;文本数据处理1前言1、分词2.将把提取出来的词元转换为数字ID3.添加特殊上下文标记4. 字节对编码&#xff08;以及tiktoken库无法下载gpt2参数&#xff0c;调用g…

【AI工具】解放双手,操控浏览器的工具对比,来了

&#x1f4d2;前言在github上面&#xff0c;有几个操作浏览器的mcp工具&#xff1a;browser-use / browser-usemicrosoft / playwright-mcpAgentDeskAI / browser-tools-mcphangwin / mcp-chrome想知道他们的区别吗&#xff0c;想知道那个更适合你吗&#xff0c;想。。。&#…

Linux 操作系统基础知识总结

1、操作系统总体介绍 CPU&#xff1a; 就像人的大脑&#xff0c;主要负责相关事情的判断以及实际处理的机制。 查询指令&#xff1a; cat /proc/cpuinfo 内存&#xff1a; 大脑中的记忆区块&#xff0c;将皮肤、眼睛等所收集到的信息记录起来的地方&#xff0c;以供CPU进行判断…

cudagraph 本质详解

理解 CUDA Graph 的本质,关键在于理解它解决了什么问题,以及它通过什么机制来解决这个问题。 一、 核心问题:传统 CUDA 编程的“CPU 瓶颈” 在 CUDA Graph 出现之前,我们通常使用 CUDA Stream 来向 GPU 提交任务。这是一个动态的过程: CPU 作为指挥官:CPU 循环地、逐条…

Spring MVC 父子容器深度解析:原理、实战与优化

1. 父子容器的定义与设计初衷一句话总结&#xff1a;父子容器的核心价值在于解耦 Web 层与业务层&#xff0c;实现职责分离与上下文隔离。1.1 父子容器的层次关系在 Spring MVC 中&#xff0c;容器分为两类&#xff1a;父容器&#xff08;Root ApplicationContext&#xff09;&…