Warshall算法

简介: Warshall算法

前言


 Warshall算法是一种经典的图论算法,用于计算给定有向图的传递闭包。在本文中,我们将详细介绍Warshall算法,并通过图例来演示算法的执行过程。


什么是传递闭包?


d45f610aa211ba7f42735f27bd677983_483b46486eda481e8775a5f1323c7ab3.png


 在离散数学中,如果存在一个有向图中的节点u可以直接和间接到达另一个节点v,则称u可以到达v。如果对于图中的所有节点对(u,v),都存在一条从u到v的有向路径,则称该图是传递的。传递闭包则表示所有可达性的集合。


Warshall算法的原理


 在我们写程序计算传递闭包时通常会这样写:


5d94c75a1de4a5981063cab1a473713d_8b861db002014e87b3c076aed94c1bda.png


 这样的时间复杂度为O(n^4),为了简化该算法的复杂度,Warshall算法使用动态规划的思想,通过多次迭代,计算有向图的传递闭包。

具体算法:


初始化可达矩阵。将可达矩阵的值初始化为邻接矩阵的值。

逐步构建可达矩阵。对于每一对顶点i和j,如果存在一条从i到j的路径或者存在一条从i到k的路径和一条从k到j的路径,那么我们就可以说顶点i可达顶点j。

因此,我们可以使用以下公式来逐步构建可达矩阵。


T[i][j]=T[i][j]||(T[i][k]&&T[k][j];


其中,reach[i][j]表示从顶点i是否可达顶点j,k是一个介于1和n之间的中间顶点。


最终可达矩阵即为该图的传递闭包。


完整伪代码:


37f227d9b7663db01e8a66d01bb88fcb_124a09c58ed343ab95cfc3b754c36d54.png


总结:


 其实简单的说,传递闭包就是让“间接到达”变成直接到达。所以我们通过k遍历了所有的间接情况,通过∪和∩得到了最后的矩阵。


 更新不易,辛苦各位小伙伴们动动小手,👍三连走一走💕💕 ~ ~ ~ 你们真的对我很重要!最后,本文仍有许多不足之处,欢迎各位认真读完文章的小伙伴们随时私信交流、批评指正!

目录
相关文章
|
机器学习/深度学习 人工智能 自然语言处理
算法
算法
77 2
|
4月前
|
算法
算法题(6)
算法题(6)
29 7
|
5月前
|
算法
Manacher(马拉车)算法详解
该文章详细解释了Manacher算法,这是一种高效找出给定字符串最长回文子串的算法,通过在字符串中插入特殊字符构建新的字符串,并利用中心扩展策略来找出最长回文序列,时间复杂度为O(N),空间复杂度为O(N)。
|
6月前
|
存储 传感器 编解码
|
8月前
|
算法
多边形裁剪算法
多边形裁剪算法
|
存储 并行计算 算法
FlashAttention算法详解
这篇文章的目的是详细的解释Flash Attention,为什么要解释FlashAttention呢?因为FlashAttention 是一种重新排序注意力计算的算法,它无需任何近似即可加速注意力计算并减少内存占用。所以作为目前LLM的模型加速它是一个非常好的解决方案,本文介绍经典的V1版本,最新的V2做了其他优化我们这里暂时不介绍。因为V1版的FlashAttention号称可以提速5-10倍,所以我们来研究一下它到底是怎么实现的。
587 0
|
算法
蚂群算法
蚂群算法
111 0
蚂群算法
|
算法
算法题:出现
题目: 给定 n 个自然数,求没有在这 n 个自然数中出现过的最小的自然数是多少。
123 0
|
人工智能 算法 搜索推荐
线性排序算法(1)
排序 选择排序(适用于线性排序) 思路,2层遍历 第一步:选择最小的元素,与第一个元素交换。 第二步:从第二个元素到最后一个元素,选择最小元素,与第二元素交换 完成前两步,第1第2元素已经排好序。
1015 1

热门文章

最新文章

下一篇
开通oss服务