【数据结构学习笔记】关于迪杰斯特拉 图 的 最短路径 理解

先把内容放一下:

如果注意到最短路径点的下标和最短路径的权值数组,权值数组作为的是一种标准,衡量是否为最短路径的标准。

在每一次循环中都会进行更新(前提是满足了权值的最小条件的情况)。

上述的思路没有问题,自己在看的时候我自己在纸上记录了每次的循环结果对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的最优结果

其实任何的找最短距离的都需要记录路径的更新,更新很重要

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值