上午看了一下 spfa 算法的优化,在练习的时候发现 dij 还可以优化,打算明天学习一下。
关于今天的 dijkstra 和 spfa 算法,dijkstra 算法和 Prim 算法相似,维护 d 数组,d[i] 一般表示从原点到达 i 位置的最短距离,当然可以根据题目要求变通,只要弄懂贪心过程这里还是比较好理解的
如上图所示:
假设原点是 1,维护 d 数组,d[i] 表示 1~i 节点的最小距离
首先初始化 d[i]=inf; d[1]=0
找出距原点最近的点,d[2]=3
然后更新 d[3]=3+2 , d[4]=3+9
再找出距原点最近的点, d[5]=3
然后更新 d[4]=3+2
再找出距原点最近的点 3, d[3]=5
只能更新 d[4]=5+4,但是上一步有 d[4]=3+2,所以不更新
这样 2,5,3 点依次更新完了,在查看 d[4] ,发现 d[4] 无需更新,所以结束