最短路径算法

SPFA:SPFA(Shortest Path Faster Algorithm)(队列优化)算法是求单源最短路径的一种算法,它还有一个重要的功能是判负环(在差分约束系统中会得以体现),在Bellman-ford算法的基础上加上一个队列优化,减少了冗余的松弛操作,是一种高效的最短路算法。

单源最短路径 就是起点固定,求从起点到各个顶点的最短路径。

下面从百度百科中给的图例来解释spfa算法;

不妨设a点为起点即 源;

spfa需要定义的变量:

int start;起点

int n;一共n个点

int d[N];  源点到点i的最短路

int p[N];  //记录路径(或者说记录前驱)

queue <int> q;队列

bool vis[N];记录点i是否在队列中

算法过程:

初始化:队列q中push起点a;



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值