先把内容放一下:
如果注意到最短路径点的下标和最短路径的权值数组,权值数组作为的是一种标准,衡量是否为最短路径的标准。
在每一次循环中都会进行更新(前提是满足了权值的最小条件的情况)。
上述的思路没有问题,自己在看的时候我自己在纸上记录了每次的循环结果对final、pathMatrix、ShotPathTable的更新记录。
从
这个i=3以后我们开始手动循环并进行更新final、pathMatrix、ShotPathTable数组:
i = 4, min = 7, k = 3;
final = {1,1,1,1,1,0,0,0,0};
D = {0,1,4,7,5,8,10,14,65535};
P = {0,0,1,4,2,4,3,4,0};
i = 5,min = 8, k = 5;
final = {1,1,1,1,1,1,0,0,0,0};
D = {0,1,4,7,5,8,10,13,65535};
P = {0,0,1,4,2,4,3,5,0};
在v5节点时,符合要求的只能将D[7]和P[7]更新,但之后就会注意到,在I的递增循环下,会出现更短的权值数组,所以还是会进行更新,不会对结果造成影响,这一点很重要,如果不明白最好画一下;
i = 6, min = 10, k = 6;
final = {1,1,1,1,1,1,1,0,0};
D = {0,1,4,7,5,8,10,12,17};
P = {0,0,1,4,2,4,3,6,6};
解释,以当前节点v6进行向下一邻接节点进行最短路径和权值进行更新
i = 7, min = 12, k = 7;
final = {1,1,1,1,1,1,1,1,0};
D = {0,1,4,7,5,8,10,12,16};
P = {0,0,1,4,2,4,3,6,6};
解释,以当前节点v7进行向下一邻接节点进行最短路径和权值进行更新
i = 8,k = 8,min = 16;
final = {1,1,1,1,1,1,1,1,1};
D = {0,1,4,7,5,8,10,12,16};
P = {0,0,1,4,2,4,3,6,6};
D和P不进行更新,
end
总结:主要是在i = 5 的那一个循环,要知道这次的DP变更不会对最终结果产生任何的影响,只是在V0到V5的最优结果
其实任何的找最短距离的都需要记录路径的更新,更新很重要