博客
关于我
最短路之Floyd算法
阅读量:544 次
发布时间:2019-03-07

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

最短路之Floyd算法

关于原理Floyd算法是一种用于计算图中最短路径的算法,其核心思想是通过动态规划的方式逐步优化距离矩阵。然而,需要注意的是:Floyd算法不能解决带有“负权回路”(或者叫“负权环”)的图,因为带有“负权回路”的图没有最短路。例如,假设一个图中存在1号顶点到3号顶点的负权回路,比如1→2→3→1→2→3→…,这种情况下,无法找到真正意义上的最短路径。实际上,如果一个图中存在负权环,那么这个图就不存在最短路。

图中如果有负权回路,那么Floyd算法会陷入无法终止的循环,反复寻找“更短的路径”,导致计算结果不稳定。因此,在使用Floyd算法之前,必须确保输入图中不存在负权回路。这一点是Floyd算法的重要前提条件。

Floyd算法的模板以下是一个基于C++语言实现的Floyd算法模板:

代码示例

#include 
#include
#include
#define MAXN 100#define INF 0x3f3f3f3fusing namespace std;int a[MAXN][MAXN];int n, m;void Floyd() { for(int k=1; k<=n; k++) { for(int i=1; i<=n; i++) { for(int j=1; j<=n; j++) { if(a[i][j] > a[i][k] + a[k][j]) { a[i][j] = a[i][k] + a[k][j]; } } } }}void init() { for(int i=1; i<=n; i++) { for(int j=1; j<=n; j++) { if(i == j) { a[i][j] = 0; } else { a[i][j] = INF; } } }}int main() { cin >> n >> m; for(int i=1; i<=m; i++) { int t1, t2, t3; cin >> t1 >> t2 >> t3; a[t1][t2] = t3; } Floyd(); // 输出结果 // ...}

代码说明

  • 首先包含必要的头文件,包括输入输出流、算法库和队列库。
  • 定义了顶点数为MAXN,初始化为无穷大。
  • Floyd算法的核心三重循环,通过中间点k逐步更新最短路径。
  • 初始化函数,设置顶点到自身的距离为0,其他顶点之间的距离为无穷大。
  • 主函数部分读取输入数据并调用Floyd算法,输出最短路径结果。
  • 转载地址:http://qddcz.baihongyu.com/

    你可能感兴趣的文章
    Node-RED中使用node-red-node-ui-iframe节点实现内嵌iframe访问其他网站的效果
    查看>>
    Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
    查看>>
    Node-RED中实现HTML表单提交和获取提交的内容
    查看>>
    Node.js 8 中的 util.promisify的详解
    查看>>
    Node.js 函数是什么样的?
    查看>>
    Node.js 历史
    查看>>
    Node.js 在个推的微服务实践:基于容器的一站式命令行工具链
    查看>>
    Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
    查看>>
    node.js 怎么新建一个站点端口
    查看>>
    Node.js 文件系统的各种用法和常见场景
    查看>>
    node.js 简易聊天室
    查看>>
    node.js 配置首页打开页面
    查看>>
    node.js+react写的一个登录注册 demo测试
    查看>>
    Node.js中环境变量process.env详解
    查看>>
    Node.js卸载超详细步骤(附图文讲解)
    查看>>
    Node.js安装与配置指南:轻松启航您的JavaScript服务器之旅
    查看>>
    Node.js安装及环境配置之Windows篇
    查看>>
    Node.js安装和入门 - 2行代码让你能够启动一个Server
    查看>>
    node.js安装方法
    查看>>
    Node.js的循环与异步问题
    查看>>