数据结构:点对之间最短距离--Floyd算法

Floyd算法是一种动态规划策略,用于找出图中所有点对之间的最短路径,不同于Dijkstra算法的贪心策略。算法考虑两种情况:两点直接相连的最短路径和通过中介点的最短路径。文中提供了算法思想和代码实现。
摘要由CSDN通过智能技术生成

                           Floyd算法

Floyd算法

    Dijkstra算法是用于解决单源最短路径问题的,Floyd算法则是解决点对之间最短路径问题的。Floyd算法的设计策略是动态规划,而Dijkstra采取的是贪心策略。当然,贪心算法就是动态规划的特例。

算法思想

    点对之间的最短路径只会有两种情况:

  1. 两点之间有边相连,weight(Vi,Vj)即是最小的。
  2. 通过另一点:中介点,两点相连,使weight(Vi,Vv)+weight(Vv,Vj)最小。
Min_Distance(Vi,Vj)=min{ weight(Vi,Vj),weight(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值