Floyd 算法学习笔记

技术Floyd 算法学习笔记 Floyd 算法学习笔记Floyd算法学习笔记(未完结)
前言
如有错误,欢迎各位 dalao 批评指出。
前置芝士:
1.邻接矩阵(Floyd要用邻接矩阵存图)
2.动态

弗洛伊德算法学习笔记

Floyd算法学习笔记(未完结)

前言

如有错误,欢迎大劳批评指出。

前置芝士:

1.邻接矩阵(弗洛伊德想用邻接矩阵保存图形)

2.动态规划的思路(最好学一学,没学的话影响不大)

1. Floyd 所解决问题的类型

我们可以发现,诸如Dijkstra、SPFA、Bellman Ford等最短路径算法都解决了单源点的最短路径问题,即确定起点或终点来寻找最短路径问题。然而,我们发现这些算法效率太低,无法解决具有多个源的最短路径问题,即具有多个起点和终点的最短路径问题。假设有\(n\)个点和\(m\)条边。在求解多源最短路径时,如果用上述三种算法求解,则需要分别做\(n\)次才能从每个点开始求解单源最短路径。最慢的时间复杂度是\ (o (nlogm),o (n 2m),o (n 2m) \),在稠密图中\ (m=n)因此,我们今天的主角Floyd就是为了解决多源最短路径问题而诞生的!

2. Floyd 的思想和基本做法

弗洛伊德算法的基本思想是动态规划。

让\(dp_{ij}\)代表从\(i\)到\(j\)的最短距离。(有\(n\)个点)

首先,这个\(dp\)数组的初始化是将输入边\(x-y\)的权重设置为\(z\)(加权图为\(1\)),如果图是无向图,那么\(dp_{xy}=dp_{yx}=z\)

然后我们进行状态转换。显然,如果我们想转移\(dp_{ij}\),我们需要找到一个点\(k\)来转移,那就是\ (DP _ {ij} \ getsmin (DP _ {ij},DP _ {ik} DP _ {kj}) \)

这里需要注意的是,我们的\(k\)层循环必须放在\(i\)和\(j\)层循环之外,因为如果放在\(i,j\)内,你会发现每两点的最短路径只会被计数一次,当你处于状态转换时,你只

Floyd算法的时间复杂度为\(o(n ^ 3)\),因为\(i,j,k\)必须枚举一层循环,比前三种算法快。

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/100417.html

(0)

相关推荐

  • MySQL应该学习的6件事是什么

    技术MySQL应该学习的6件事是什么本篇内容介绍了“MySQL应该学习的6件事是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够

    攻略 2021年12月3日
  • 广东去哪里旅游比较好,广东有什么地方好玩又便宜啊

    技术广东去哪里旅游比较好,广东有什么地方好玩又便宜啊广州→梅关→始兴→丹霞→连南→英德 风情 指北针向着广州正北方位,出发广东去哪里旅游比较好! 在粤北,广袤的山区是客家人的领地,这个组分了广东三大人系中最大数量的人群,

    生活 2021年10月28日
  • Oracle 12c R2版本 Application Containers的特性是什么

    技术Oracle 12c R2版本 Application Containers的特性是什么本篇文章给大家分享的是有关Oracle 12c R2版本 Application Containers的特性是什么,小编觉得挺实

    攻略 2021年11月12日
  • 用比喻的修辞手法写一句话,运用比喻、拟人的修辞手法写句子

    技术用比喻的修辞手法写一句话,运用比喻、拟人的修辞手法写句子1用比喻的修辞手法写一句话、一阵风吹来,树摆动着枝叶,对我们点头微笑。 2、玫瑰在宁静的夜晚向星星眨眼。 3、无数的麦粒在风中微笑,飞舞。 4、在绿色的荷叶间,

    生活 2021年10月22日
  • 如何进行实战和剖析Sentinel 系统自适应限流

    技术如何进行实战和剖析Sentinel 系统自适应限流这篇文章将为大家详细讲解有关如何进行实战和剖析Sentinel 系统自适应限流,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定

    攻略 2021年10月21日
  • css3消除锯齿的属性怎么使用(设置消除锯齿方法)

    技术css3消除锯齿的属性怎么使用本篇内容介绍了“css3消除锯齿的属性怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有

    攻略 2021年12月15日