大意:
弗洛伊德算法所求的是各个点之间的最小路径 这里的核心思想大致是这个样子,比如说你要从学校一教走到四教,中间经过的距离是10KM,这时如果你是先从一教走到风雨操场再到四教有可能只需要8KM,那么还有可能假如你是从一教到风雨再到数图再到四教发现距离只需要6KM。
按我们图中的这个例子,假如现在我要从1→3 直接走是6步 这时我们发现如果经过2 即1→2→3这样的话只需要5步
那么如何实现它呢只需要 min(e[i][j],e[i][2]+e[2][j])
i→ j的意思是从点I到点j
那么我们将它扩展开来 假如计算每两个点通过2以后会不会使距离变得太短
//经过2号顶点
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
if (e[i][j] > e[i][2]+e[2][j]) e[i][j]=e[i][2]+e[2][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];
完整程序
`#include <stdio.h>
int main()
{
int e[10][10],k,i,j,n,m,t1,t2,t3;
int inf=99999999;
//读入n和m,n表示顶点个数,m表示边的条数
scanf("%d %d",&n,&m);
//初始化
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
if(i==j) e[i][j]=0;
else e[i][j]=inf;
//读入边
for(i=1;i<=m;i++)
{
scanf("%d %d %d",&t1,&t2,&t3);
e[t1][t2]=t3;
}
//Floyd-Warshall算法核心语句
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");
}
return 0;
}