图论-DAG图中的最短路问题

图论-DAG图中的最短路问题

根据节点的拓扑排序的次序来对带权重的有向无环图进行边的松弛操作,我们便可以在 Θ ( V + E ) \Theta(V+E) Θ(V+E)的时间内计算出从单个源节点到所有节点之间的最短路径。

因为DAG无环,因此不存在负权环,因此源节点到任意的最短路都是存在的。我们只需要按照拓扑排序的次序,来依次松弛节点的邻接边,即可。

证明

对于任意s到v的最短路 ( v 0 , v 1 , … , v k ) (v_{0},v_{1},\dots,v_{k}) (v0,v1,,vk) v 0 = s , v k = v v_{0}=s,v_{k}=v v0=s,vk=v,边的松弛永远是按照 ( v 0 , v 1 ) (v_{0},v_{1}) (v0,v1) ( v 1 , v 2 ) (v_{1},v_{2}) (v1,v2)次序进行松弛的,因为这个最短路符合拓扑排序的次序,边的松弛又是按照拓扑排序进行松弛的。因此,这个算法是正确的。

时间复杂度为 Θ ( V + E ) \Theta(V+E) Θ(V+E),线性。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值