弗洛伊德算法(Floyd-Warshall)
admin
2024-04-14 15:18:25
0

预计阅读时间:10分钟

一、简介

       弗洛伊德算法又名插点法,是一种利用动态规划的思想寻找给定的加权图中多源点之间最短路径的算法。

       弗洛伊德算法是一种在具有正或负边缘权重但没有负周期的加权图中找到最短路径的算法。算法的单个执行将找到所有顶点对之间的最短路径的长度(加权)。 虽然它不返回路径本身的细节,但是可以通过对算法的简单修改来重建路径。 该算法的版本也可用于查找关系R的传递闭包,或在加权图中所有顶点对之间的最宽路径。

二、核心思路

路径矩阵

        即通过一个图的权值矩阵求出它的每两点间的最短路径矩阵。 

        从图的带权临接A=[a(i,j)] n×n开始,迭代地进行n次更新,即由矩阵D(0)=A,按一个公式,构造出矩阵D(1);又用同样地公式由D(1)构造出D(2);……;最后又用同样的公式由D(n-1)构造出矩阵D(n)。矩阵D(n)的i行j列元素便是i号顶点到j号顶点的最短路径长度,称D(n)为图的距离矩阵,同时还可引入一个后继节点矩阵path来记录两点间的最短路径。

状态转移方程

map[i,j]:=min{map[i,k]+map[k,j],map[i,j]};

        map[i,j]表示i到j的最短距离,K是穷举i,j的断点,map[n,n]初值应该为0,或者按照题目意思来做。

        当然,如果这条路没有通的话,还必须特殊处理,比如没有map[i,k]这条路。

过程

  1. 从任意一条单边路径开始。所有两点之间的距离是边的权,如果两点之间没有边相连,则权为无穷大。
  2. 对于每一对顶点 u 和 v,看看是否存在一个顶点 w 使得从 u 到 w 再到 v 比已知的路径更短。如果是更新它。

三、优缺点及时间空间复杂度 

优点:简单。

缺点:时间复杂度比较高。

时间复杂度:O(n^3)

空间复杂度:O(n^2)

四、参考代码 

声明:以下内容来自Floyd算法_百度百科

#include
#include
using namespace std;
const int &INF=100000000;
void floyd(vector > &distmap,//可被更新的邻接矩阵,更新后不能确定原有边vector > &path)//路径上到达该点的中转点
//福利:这个函数没有用除INF外的任何全局量,可以直接复制!
{const int &NODE=distmap.size();//用邻接矩阵的大小传递顶点个数,减少参数传递path.assign(NODE,vector(NODE,-1));//初始化路径数组 for(int k=1; k!=NODE; ++k)//对于每一个中转点for(int i=0; i!=NODE; ++i)//枚举源点for(int j=0; j!=NODE; ++j)//枚举终点if(distmap[i][j]>distmap[i][k]+distmap[k][j])//不满足三角不等式{distmap[i][j]=distmap[i][k]+distmap[k][j];//更新path[i][j]=k;//记录路径}
}
void print(const int &beg,const int &end,const vector > &path)//传引用,避免拷贝,不占用内存空间//也可以用栈结构先进后出的特性来代替函数递归 
{if(path[beg][end]>=0){print(beg,path[beg][end],path);print(path[beg][end],end,path);}else cout<<"->"<>n_num>>e_num;vector > path,distmap(n_num,vector(n_num,INF));//默认初始化邻接矩阵for(int i=0,p,q; i!=e_num; ++i){cout<<"输入第"<>p>>q;cin>>distmap[p][q];}floyd(distmap,path);cout<<"计算完毕,可以开始查询,请输入出发点和终点:";cin>>beg>>end;cout<<"最短距离为"<

以上就是本文的全部内容啦!感谢阅读!

相关内容

热门资讯

原创 四... 浮躁,几乎是每个人都经历过的状态,我自己也不例外。每天,我总会在脑海中幻想,什么时候才能一夜暴富,抛...
第十一篇,连锁企业扩张:别把资... 连锁企业的扩张之战,从来不是“广撒网、多敛鱼”的盲目博弈,而是“精准聚焦、集中发力”的战略取舍。前文...
原创 假... “关羽大意失荆州”这一典故,无论历史课本还是民间传说中都耳熟能详。人们普遍认为,关羽的失误和疏忽注定...
标普500银行指数下跌2.2%... 标普500银行指数下跌2.2%。 来源:金融界AI电报
董宇辉未来在直播带货和内容创作... 来源:新浪乐迷公社 从东方甄选独立后,董宇辉以“与辉同行”为起点,正通过战略重构直播带货与内容创作的...
国开行2025年发放公路基础设... 记者从国家开发银行获悉,2025年,国开行发放公路基础设施贷款超3600亿元,同比增长10%。“十四...
2月23日晚间重要公告集锦 前沿生物:与葛兰素史克签署授权许可协议;国投资本:国投瑞银白银期货证券投资基金估值调整预计对公司20...
推进民生实事许昌市妇幼保健院实... 本报讯(记者 常娟 许冬冬)作为“两癌”“两筛”工作的直接承担者,推进“两癌”(乳腺癌、宫颈癌)“两...
当区块链遇见供应链:一场透明与... 在全球化经济的浪潮中,供应链如同世界的血液循环系统,将原材料、零部件和成品跨越国界输送到每一个角落。...
深夜突发,美股全线跳水,近40... 每经编辑:何小桃,宋思艰 2月24日凌晨,美股突然跳水。 截至发稿,道指跌1.68%,跌幅超800点...
四川春节假期消费市场“马力十足... 封面新闻记者 易弋力 吃团年饭、赏花灯、观非遗、看电影、踏春旅游、以旧换新、沉浸购物……马年春节,迎...
早盘:美股走低科技股领跌 纳指... 来源:环球市场播报 北京时间2月17日晚,美股周二早盘走低,主要股指延续了上周的下跌趋势。此前遭受重...
原创 今... 已经打响的2026年家电市场“零售争夺”大战,对于行业所有厂商来说,压力巨大、压力激增。特别是,对于...
云南省属企业2025年利润同比... 记者从日前举行的全省省属企业负责人会议上获悉,2025年云南省属企业利润同比增长147.57%,增加...
集体杀跌!刚刚,13.67万人... 加密货币集体跳水! 今日(2月23日),在地缘政治紧张及美国关税不确定性上升的双重打击下,加密货币市...
国发股份详解2025年预亏原因... 每经记者:吴泽鹏 每经编辑:文多 1月17日发布2025年年度业绩预亏公告后,国发股份(SH6005...
公司上了94个“数字员工”,干... 内容来源:2026年2月12日,大树AI创业圈视频号第50期 访谈 渊虹分享内容 。 分享嘉宾: 渊...
如何构建一个完美的投票系统?必... 一、明确投票系统的需求 微信搜索关键词(中正投票)一键进入小程序,创建你需要活动模版,一键搭建专属投...
孙宇晨现身GWDC2026:定... 近日,区块链行业的年度盛事GWDC2026在万众瞩目中拉开帷幕。作为本次大会的联合主办方与钻石赞助商...
白癜风医生刘云涛:白癜风与维生... 维生素B族是人体必需的水溶性维生素,包含多种亚型,参与人体新陈代谢、神经系统调节和皮肤细胞修复,对白...