最短路径:我的理解--SPFA算法
Algorithm。 最短路径快速算法-SPFA算法是西南交通大学段凡丁于1994年发表的。

因为SPFA没有向迪杰斯塔拉算法那样,寻找dist[]的最小值,所以重复入队,更新dis[]的最小值,因为这个点本身dis[]的变化,会影响到与之邻接的点,所以要重复入队。
int INF =
999999;
map[MAXN][MAXN];
//map[i,j]为初始输入的i到j的距离,未知的map[i,j]=INF;
dis[MAXN];//源点S到i的最短路
Q[MAXN];//队列
参数n表示结点数,s表示源点
int s)
i, pri, end, p, t;
// pri是队列头结点,end是队列尾结点
memset(vst,
0, sizeof(vst));//初始化
for(int
i=0; i<</b>MAXN; ++i)
Q[i] =
0;//初始化队列为空
for (i=0; i<</b>n; i++)
dis[i] =
INF;//初始化源点到I的值为最大值
dis[s] =
0;//源点为0
vst[s] =
1;//标记为已入队
s;//源点入队
= 1;//队首队尾赋值
while (pri
<</b> end)
{
p = Q[pri];//取队首元素
for (i=0; i<</b>n; ++i)
//更新dis
{ if (dis[p]+map[p][i] <</b> dis[i])
{
dis[i] =
dis[p]+map[p][i];
if (!vst[i])
//未在队列中
{
Q[end++]
= i;
vst[i] =
1;
}
}
}
vst[p] =
0; //
置出队的点为未标记
pri++;
}
return 1;
初始结点s,即为起点,若目标结点t,则输出dict[t]。
init_data(s);
int head = 0, tail = 1;
int path[Max]; //
可增加一个path[]数组来记录最后s到t的路径。
= s; //que.push(s);
dict[s] = 0;
while (tail >
head)//(!que.empty())
int u = queue[head];//int
u=que.front();
//que.pop();
vis[u] = true;
for (i = 1; i <= n; i ++)
{ if (dict[i] > dict[u] +
edge[u][i])
{ dict[i] = dict[u] +
edge[u][i];
path[i] = u;
num[i]++
if(num[i]>=n) return 1;//判断是否有负权值……
if (!vis[i])
// 对以前没有访问过的顶点,加入队列中。
{ vis[i] = true;
queue[tail] = i;// que.push(i);
tail
++;
}
}
}
vis[u] = false; //
记得把出队列的顶点的vis[]置为false。
head ++;
}
num[i]>=n的原因,即使所有的点更新都会让i入队的话,才只有n-1次,这时一定是最小值了,入队n次,一定有负权回路
最短路径:我的理解--SPFA算法的更多相关文章
- SPFA算法——最短路径
粗略讲讲SPFA算法的原理,SPFA算法是1994年西南交通大学段凡丁提出 是一种求单源最短路的算法 算法中需要用到的主要变量 int n; //表示n个点,从1到n标号 int s,t; //s ...
- 【算法】单元最短路径之Bellman-Ford算法和SPFA算法
SPFA是经过对列优化的bellman-Ford算法,因此,在学习SPFA算法之前,先学习下bellman-Ford算法. bellman-Ford算法是一种通过松弛操作计算最短路的算法. 适用条件 ...
- (转)SPFA算法
原文地址:http://www.cnblogs.com/scau20110726/archive/2012/11/18/2776124.html 粗略讲讲SPFA算法的原理,SPFA算法是1994年西 ...
- SPFA 算法(剪辑)(学习!)
SPFA算法 单源最短路径的算法最常用的是Dijkstra,些算法从时间复杂度来说为O(n^2),但是面对含有负权植的图来说就无能为力了,此时 Dellman-ford算法就有用了,这咱算法是采用的是 ...
- 转载:SPFA算法学习
转载地址:http://www.cnblogs.com/scau20110726/archive/2012/11/18/2776124.html 粗略讲讲SPFA算法的原理,SPFA算法是1994年西 ...
- 数据结构与算法--最短路径之Bellman算法、SPFA算法
数据结构与算法--最短路径之Bellman算法.SPFA算法 除了Floyd算法,另外一个使用广泛且可以处理负权边的是Bellman-Ford算法. Bellman-Ford算法 假设某个图有V个顶点 ...
- (最短路径算法整理)dijkstra、floyd、bellman-ford、spfa算法模板的整理与介绍
这一篇博客以一些OJ上的题目为载体.整理一下最短路径算法.会陆续的更新... 一.多源最短路算法--floyd算法 floyd算法主要用于求随意两点间的最短路径.也成最短最短路径问题. 核心代码: / ...
- 最短路径问题的Dijkstra和SPFA算法总结
Dijkstra算法: 解决带非负权重图的单元最短路径问题.时间复杂度为O(V*V+E) 算法精髓:维持一组节点集合S,从源节点到该集合中的点的最短路径已被找到,算法重复从剩余的节点集V-S中选择最短 ...
- 最短路径--SPFA 算法
适用范围:给定的图存在负权边,这时类似Dijkstra等算法便没有了用武之地,而Bellman-Ford算法的复杂度又过高,SPFA算法便派上用场了. 我们约定有向加权图G不存在负权回路,即最短路径一 ...
随机推荐
- 56、isinstance作用以及应用场景?
isinstance作用:来判断一个对象是否是一个已知的类型: 其第一个参数(object)为对象,第二个参数为类型名(int...)或类型名的一个列表((int,list,float)是一个列表). ...
- php上传文件大小限制的方法详解
打开php.ini,首先找到file_uploads = on ;是否允许通过HTTP上传文件的开关.默认为ON即是开upload_tmp_dir ;文件上传至服务器上存储临时文件的地方,如果没指定就 ...
- 环境变量配错了 command not found
一般就是忘记在PATH 前面加$ 1.可以用whereis或者which命令查看一下有没有这个命令 具体执行which lswhereis ls 2.系统环境变量导致的问题解决方案: exportPA ...
- sqlite3_get_table()
{ sqlite3 *db; char *errmsg=NULL; //用来存储错误信息字符串 char ret=0; int my_age=0; //类型根据要提取的数据类型而定 cha ...
- java线上应用故障排查之二:高内存占用【转】
前一篇介绍了线上应用故障排查之一:高CPU占用,这篇主要分析高内存占用故障的排查. 搞Java开发的,经常会碰到下面两种异常: 1.java.lang.OutOfMemoryError: PermGe ...
- css3动画详解
一.Keyframes介绍: Keyframes被称为关键帧,其类似于Flash中的关键帧.在CSS3中其主要以“@keyframes”开头,后面紧跟着是动画名称加上一对花括号“{…}”,括号中就是一 ...
- 在ubuntu 上安装pycharm
1.首先在官网下载pycharm并进行提取,将提取的文件夹放在/usr下面(或者任意位置) 2.然后vi /etc/hosts 编辑 将0.0.0.0 account.jetbrains.com添加到 ...
- 在Linux上安装pycharm
1.首先在官网下载pycharm并进行提取,将提取的文件夹放在/usr下面(或者任意位置) 2.然后vi /etc/hosts 编辑 将0.0.0.0 account.jetbrains.com添加到 ...
- NTP算法
网络时间协议 由特拉华大学的David L. Mills热心提供.http://www.eecis.udel.edu/~mills mills@udel.edu 由Reinhard v. Hanxle ...
- hdu 5912(迭代+gcd)
Fraction Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Su ...