Floyd - Warshall 算法
来源:互联网 发布:怪物猎人3数据库 编辑:程序博客网 时间:2024/05/18 00:33
算法只有五句代码,来计算任意两个城市间最短路径
4个城市 8条线路 ,用图来表示相邻城市的距离
代码为:
a[1][1]=0 代表从城市1 到城市1 不动,距离为0
a[1][2]=2 代表城市1到城市2距离为2
a[2][1]=inf 代表城市2 不能直接回到城市1 距离无限大
4->3 = 12
4->1->3=5+6=11<12
因此引入第三个点的时候—–有可能使得两点间的距离变短,
因此,按顺序引入1.让两点间一定要经过1,如果发现比原先的数值小,就进行替换
a[4][3]由12 变成了11
同理a[3][2]=a[3][1]+a[1][2]=7+2=9<%%
a[4][2]=a[4][1]+a[1][2]=5+2=7<%%
现在就把最小值进行变更,
到目前为止所有点如果经过点1 会变小总路径的都考虑进去了。。。
接下来就考虑需要经过点1 也要经过点2————-就在新的图继续找
a[1][3]= a[1][2]+a[2][3]=2+3=5<6
a[4][3]= a[4][2]+a[2][3]=7+3=10<11
类推—-经过了1—2—-3—-4 每次发现经过第三个点的的路径比原来两点间的距离小,
就进行替换操作—–写成代码:
- (void)main{ int e[10][10],k,i,j,n,m; int inf = 99999999;//用inf存储一个我们认为的正无穷值 //读入n和m,n表示顶点个数,m表示边的条数 n=4;m=8; for (i=1; i<=n; i++) for (j=1; j<=n; j++) if (i==j) e[i][j]=0; else e[i][j]= inf; e[1][2]=2; e[1][3]=6; e[1][4]=4; e[2][3]=3; e[3][1]=7; e[3][4]=1; e[4][1]=5; e[4][3]=12; //Floyd - Warshall 算法核心语句 //核心思想:从i号顶点到j号顶点只经过前k号点的最短路径 ,代表按顺序经过 //k=1,=2,=3=4的路径,遇到小的就替换原来的数值。。。。。。e[i][j]代表所在点的数值 for (k=1; k<=n; k++) for (i=1; i<=n;i++ ) for (j=1; j<=n; j++) if (e[i][j]>e[i][k] + e[k][j]) e[i][j] = e[i][k]+e[k][j]; for (i=1; i<=n; i++) { for (j=1; j<=n; j++) { printf("%10d",e[i][j]); } printf("\n"); }}
显示的结果
画图显示就是
时间复杂度为N*N*N
0 0
- Floyd-Warshall算法(Floyd-Warshall algorithm)
- Floyd-Warshall 算法
- Floyd-Warshall算法
- poj1125 Floyd-Warshall算法
- Floyd-Warshall算法详解
- Floyd-Warshall算法
- Floyd-Warshall算法
- Floyd-Warshall算法
- Floyd-Warshall算法
- 复习Floyd-Warshall算法
- Floyd-Warshall算法详解
- ACM_Floyd-Warshall (Floyd) 算法
- Floyd-Warshall算法
- floyd-warshall算法
- Floyd-Warshall算法
- Floyd-Warshall算法
- Floyd - Warshall 算法
- Floyd-Warshall算法
- 静态内部类
- Fresco library "libwebp.so" not found
- 物品装箱问题
- Android APP安装后不在桌面显示图标的应用场景举例和实现方法
- ERR_print_errors_fp(stdout)
- Floyd - Warshall 算法
- 关于机器学习必须要了解的几个要点(A Few Useful Things to Know about Machine Learning)
- 关于表单类元素的兼容问题
- listview优化
- Python学习-yield浅析和send()函数
- Effective Java读书笔记
- 数据字典以及业务标识字段,利用dozer和拦截器统一翻译回显页面
- 深入理解SELinux SEAndroid(第一部分)
- java创建二维码