计算多源最短路径 ----- floyd算法

Posted kang000

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了计算多源最短路径 ----- floyd算法相关的知识,希望对你有一定的参考价值。

题目链接:https://vjudge.net/contest/146629#problem/L

题目描述:有n个星球,起点在第一个星球,求走遍全部星球的 到达时间和 最小值

解题过程:

记其中第 个星球到达第 个星球所需时间为 t[i][j]

进行floyd算法处理可得到第 个星球到达第 个星球所需的最小时间:

    for (k = 1; k <= n; k++)
        for (i = 1; i <= n; i++)
            for (j = 1; j <= n; j++)
                t[i][j] = min(t[i][k] + t[k][j], t[i][j]);

 

 

接着用dfs对各个星球进行搜索即可

剪枝:

①当前时间 + 从该星球到所有未到达星球所需时间 < 所有未到达星球的时间限制

②(重要)当前到达时间和 + (n - 到达星球数) 当前到达时间 < 已知最小结果

 

 

Floyd算法为什么把k放在最外层? ------ 知乎 https://www.zhihu.com/question/30955032

 

以上是关于计算多源最短路径 ----- floyd算法的主要内容,如果未能解决你的问题,请参考以下文章

(建议收藏)一文多图,彻底搞懂Floyd算法(多源最短路径)

(建议收藏)一文多图,彻底搞懂Floyd算法(多源最短路径)

Floyd算法解决多源最短路径问题

Floyd 算法求多源最短路径

44-Floyd 算法

多源最短路径--Floyd-Warshall算法