void Floyd(){
for(int k = 1; k <= n; ++k) {
for(int i = 1; i <= n; ++i) {
for(int j = 1; j <= n; ++j) {
dis[i][j] = min(dis[i][j], dis[i][k] + dis[k][j]);
}
}
}
}

意思是以此使用k作为中转点尝试从k绕路得到新的最短两点距离。

所以只使用其中的一些k,就可以得到不经过其他点的最短路的效果。看起来有点Prim求最小生成树以及匈牙利算法的感觉,是那种可以随时停止的?

https://www.luogu.org/problem/P1119

按时间顺序加入k点,更新最短路。

#include<bits/stdc++.h>
using namespace std;
typedef long long ll; const int MAXN = 205; int n, m, t[MAXN];
int dis[MAXN][MAXN]; const int INF = 0x3f3f3f3f; int main() {
#ifdef Yinku
freopen("Yinku.in", "r", stdin);
#endif // Yinku
scanf("%d%d", &n, &m);
for(int i = 1; i <= n; ++i)
for(int j = 1; j <= n; ++j)
dis[i][j] = INF;
for(int i = 1; i <= n; ++i)
dis[i][i] = 0;
for(int i = 1; i <= n; ++i)
scanf("%d", &t[i]); for(int i = 1; i <= m; ++i) {
int u, v, w;
scanf("%d%d%d", &u, &v, &w);
++u,++v;
dis[u][v] = w;
dis[v][u] = w;
}
int q;
scanf("%d", &q);
int curti = 1;
while(q--) {
int u, v, T;
scanf("%d%d%d", &u, &v, &T);
++u,++v;
while(curti <= n && t[curti] <= T) {
for(int i = 1; i <= n; ++i) {
for(int j = 1; j <= n; ++j) {
dis[i][j] = min(dis[i][j], dis[i][curti] + dis[curti][j]);
}
}
++curti;
}
if(t[u] > T || t[v] > T)
puts("-1");
else
printf("%d\n", dis[u][v] < INF ? dis[u][v] : -1);
}
return 0;
}

最新文章

  1. 对一个目录的文件从cp936转换成utf-8
  2. RFID 读写器 Reader Writer Cloner
  3. asp.net的decimal保留两位小数
  4. mysql教程-触发器
  5. TCP/IP笔记 三.运输层(2)——TCP 流量控制与拥塞控制
  6. swiper display:none 后 在显示 滑动问题
  7. javascript语法之Date对象与小案例
  8. forfiles删除过期文件robocopy
  9. web scraper——简单的爬取数据【二】
  10. Jetpack 架构组件 Room 数据库 ORM MD
  11. SpringCloud(一)浅谈SpringCloud
  12. url参数+,&amp;,=,/等转义编码
  13. P1230 智力大冲浪
  14. Python中什么是变量
  15. 0009 - WebFlux
  16. Owin中间件动手做
  17. [leetcode]Add Binary @ Python
  18. php7+apache2.4 (Windows7下)安装
  19. Python之logging日志模块
  20. Cognos开发自定义排序规则的报表和自定义排名报表

热门文章

  1. z-tree的使用
  2. 微信小程序访问后台出现 对应的服务器证书无效。控制台输入 showRequestInfo() 可以获取更详细信息。
  3. TCP连接的11种状态,三次握手四次挥手原因
  4. springboot(一).初识springboot以及基本项目搭建
  5. 基于AdminLTE的jquery头像更新
  6. EasyUI combobox下拉框添加水平滚动条和垂直滚动条
  7. springMVC @response 中文乱码解决
  8. Flask基础总结
  9. 7、Shiro加密和加盐
  10. 使用 Dom4j 对XML操作!!!