Floyd - Warshall 算法

算法只有五句代码,来计算任意两个城市间最短路径

这里写图片描述

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值