dijkstra算法针对稠密图和稀疏图的两种不同策略

Dijkstra算法用于求解图中两点间最短路径,针对稠密图和稀疏图有不同的策略。在稠密图中,算法复杂度为O(n^2),通过依次找到最近未遍历点并更新相邻点的最短距离。而在稀疏图中,利用优先队列优化,算法复杂度降低到O(mlogn),通过遍历优先队列中的节点和其相邻边来更新最短路径。
摘要由CSDN通过智能技术生成

迪杰斯特拉(dijkstra)算法是一种普遍用于求两点之间(或者说一个给定点到图中其他任意点)的最短路径的算法。但当图的连接较为稠密或者较为稀疏的时候,采用两种不同的思路,可以优化算法的执行速度。

应用于稠密连接图的dijkstra算法

所谓稠密连接就是指图之间的连接路径趋近于n的平方(n为图中节点的个数)。在稠密连接的条件下,dijkstra算法的算法复杂度是O(n^2)。

算法思想是分两步走:

  • 从起点开始,依次找到距离起点最近且没有被遍历过的点。
  • 更新与这个点直接连接的点的最短距离值。

其中,更新最短距离值的状态转移方程为:
d ( y ) = m i n ( d

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值