最短路径(弗洛伊德算法)
来源:互联网 发布:大数据在传媒界的应用 编辑:程序博客网 时间:2024/05/01 01:50
迪杰特斯拉算法求的是一个顶点到所有顶点的最短路径,但弗洛伊德算法是求所有顶点到所有顶点的最短路径。
首先,来看下面这个简单的图:
我们把他的邻接矩阵和初始化的p做出来,如下图所示:
代码如下:
#define MAXVEX9#define INFINITY65535typedef int Pathmatirx[MAXVEX][MAXVEX];typedef int ShortPathTable[MAXVEX][MAXVEX];void ShortestPath_Floyd(MGraph G, Pathmatirx *P, ShortPathTable *D){int v, w, k;// 初始化D和Pfor( v=0; v < G.numVertexes; v++ ){for( w=0; w < G.numVertexes; w++ ){(*D)[v][w] = G.matirx[v][w];(*P)[v][w] = w;}}// 优美的弗洛伊德算法for( k=0; k < G.numVertexes; k++ ){for( v=0; v < G.numVertexes; v++ ){for( w=0; w < G.numVertexes; w++ ){if( (*D)[v][w] > (*D)[v][k] + (*D)[k][w] )//下标为k顶点路径比原两点间更短,设置更小的那个{(*D)[v][w] = (*D)[v][k] + (*D)[k][w];(*P)[v][w] = (*P)[v][k];//路径设置经过下标为K的顶点}}}}}
由(*D)[v][w]>(*D)[v][k]+(*D)[k][w]
指的是下面这个,并且D1和P1化为
1 0
- 弗洛伊德最短路径算法
- 弗洛伊德算法--最短路径
- 最短路径-弗洛伊德算法
- 弗洛伊德最短路径算法
- 最短路径(弗洛伊德算法)
- 最短路径--弗洛伊德算法
- 最短路径:弗洛伊德算法
- 弗洛伊德最短路径算法
- 弗洛伊德最短路径算法
- 最短路径---弗洛伊德算法
- 最短路径(弗洛伊德算法)
- 最短路径—弗洛伊德算法
- 最短路径之弗洛伊德算法(Floyd)
- 弗洛伊德变种算法计算最短路径
- 图--最短路径--弗洛伊德算法
- 最短路径之Floyd(弗洛伊德)算法
- Floyd Warshall 弗洛伊德算法---最短路径
- 最短路径--弗洛伊德(Floyd)算法
- 安卓使用MediaPlayer和SurfaceView播放视频
- git学习笔记
- 搜索的的原理代码
- Loadrunner11的一些总结
- java Servlet(二)生命周期
- 最短路径(弗洛伊德算法)
- Output Un-compensite Point Feature to TEXT file/将未补偿测量点输出到文本文件的宏
- 自定义View-之Path类
- 第五届校内选拔javaC组-第五题位平方和
- STL中的迭代器学习
- ConcurrentHashMap,hashtable以及两者比较
- android监听手机解锁
- 分数的表示和四则运算
- 动态web工程中servlet的web.xml文件的配置