博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
模板 - Floyd
阅读量:4681 次
发布时间:2019-06-09

本文共 1545 字,大约阅读时间需要 5 分钟。

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求最小生成树以及匈牙利算法的感觉,是那种可以随时停止的?

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

#include
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;}

转载于:https://www.cnblogs.com/Yinku/p/11345235.html

你可能感兴趣的文章
linux部署Oracle数据库--创建数据库
查看>>
[LeetCode] 148. Sort List 链表排序
查看>>
Java判断密码强度工具类
查看>>
阶段4-独挡一面\项目-基于视频压缩的实时监控系统\Sprint1-基于Epoll架构的采集端程序框架设计\第1课-Epoll机制精通...
查看>>
jmeter(四十四)常用性能指标分析
查看>>
6个出色的基于JQuery的Tab选项卡实例2010/01/29 16:261. jQuery 选项卡界面 / 选项卡结构菜单教程...
查看>>
F - 八苦を滅した尼公 POJ - 2763 线段树LCA
查看>>
通过jQuery源码学习javascript(一)
查看>>
源码阅读经验谈-slim,darknet,labelimg,caffe(1)
查看>>
SecureCRT配色方案
查看>>
Unity3D 关于yield在collider中的使用
查看>>
spring-mvc xml文件的最基本配置
查看>>
word 新建一行文字不能左对齐
查看>>
jquery选择器
查看>>
IT公司的等级观念
查看>>
百度编辑器ueditor1.4.3配置记录
查看>>
ubuntu12.04开启Framebuffer
查看>>
【问题和解决】python中nltk与nltk_contrib的关系
查看>>
闭包的探索
查看>>
内存泄漏
查看>>