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