
理解
代码
# -*- coding: utf-8 -*-
"""
Created on Fri May 6 13:54:10 2022
Floyd算法
用途:计算任意两点之间的最短路径
复杂度:时间复杂度O(n^3)
算法核心:
直接相连D[i][j],加入K节点后间接相连D[i][k]+D[k][i]
比较这种相连方式,哪种路径更短,将其作为两者的最短路径
"""
import numpy as np
def Floyd(D,n):
for k in range(n):
for i in range(n):
for j in range(n):
if(D[i][j]>D[i][k]+D[k][j]):
D[i][j]=D[i][k]+D[k][j]
print("第{}次".format(k+1))
print(D)
D=np.array([[0,2,np.inf,1,8],
[6,0,3,2,np.inf],
[np.inf,np.inf,0,4,np.inf],
[np.inf,np.inf,2,0,3],
[3,np.inf,np.inf,np.inf,0]])
Floyd(D,5)
结果
第1次
[[ 0. 2. inf 1. 8.]
[ 6. 0. 3. 2. 14.]
[inf inf 0. 4. inf]
[inf inf 2. 0. 3.]
[ 3. 5. inf 4. 0.]]
第2次
[[ 0. 2. 5. 1. 8.]
[ 6. 0. 3. 2. 14.]
[inf inf 0. 4. inf]
[inf inf 2. 0. 3.]
[ 3. 5. 8. 4. 0.]]
第3次
[[ 0. 2. 5. 1. 8.]
[ 6. 0. 3. 2. 14.]
[inf inf 0. 4. inf]
[inf inf 2. 0. 3.]
[ 3. 5. 8. 4. 0.]]
第4次
[[ 0. 2. 3. 1. 4.]
[ 6. 0. 3. 2. 5.]
[inf inf 0. 4. 7.]
[inf inf 2. 0. 3.]
[ 3. 5. 6. 4. 0.]]
第5次
[[ 0. 2. 3. 1. 4.]
[ 6. 0. 3. 2. 5.]
[10. 12. 0. 4. 7.]
[ 6. 8. 2. 0. 3.]
[ 3. 5. 6. 4. 0.]]
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)