暑假日记

上午看了一下 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] 无需更新,所以结束

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值