博客
关于我
图的Dijkstra算法(最短路径)
阅读量:641 次
发布时间:2019-03-14

本文共 509 字,大约阅读时间需要 1 分钟。

迪杰斯特拉算法的步骤如下:

  • 初始化:将起始节点v1的距离设为0,并将其加入优先队列。

  • 处理节点v1:从队列中取出v1,查看它的所有直接邻居节点,包括v6、v5和v3。初始化这些邻居节点v3、v5、v6的距离分别为各自边的权重。例如:

    • v3:距离10
    • v5:距离30
    • v6:距离100
  • 更新优先队列:将邻居节点加入优先队列,并标记为已访问。

  • 处理节点v3:取出v3,检查其所有邻居节点,如v2和v4。计算这些节点通过v3的距离,更新它们的最短距离:

    • v2:距离10 + 5 = 15
    • v4:距离10 + 50 = 60
  • 处理节点v5:取出v5,检查其邻居节点,发现没有未被处理的更短路径,因此不进行更新。

  • 处理节点v6:取出v6,检查其邻居节点,如未知其他节点,无需更新。

  • 处理节点v2:取出v2,无未连接节点,无需更新。

  • 处理节点v4:取出v4,检查其邻居节点,发现是否有通过v4更短的路径,若有,更新相应节点的距离。

  • 处理剩余节点:继续处理队列,算法完成。

  • 通过以上步骤,得到各节点的最短路径:

    • v1到v3的距离为10
    • v1到v2的距离为15
    • v1到v4的距离为60
    • v1到v5的距离为30
    • v1到v6的距离为100

    转载地址:http://oaulz.baihongyu.com/

    你可能感兴趣的文章
    PHP手机号码归属地查询API接口
    查看>>
    PHP执行耗时脚本实时输出内容
    查看>>
    PHP扩展安装
    查看>>
    PHP扩展数据库连接参数说明详解
    查看>>
    php把get参数放入数组_php怎么将数组转为url参数?
    查看>>
    PHP投票小程序
    查看>>
    php拆分数组不改变key值
    查看>>
    php接口返回数据 用echo 还是return?
    查看>>
    php接口返回状态,大家一般怎么规范接口返回内容
    查看>>
    php接收formdata上传的多个文件,使用formData()上传多个文件
    查看>>
    PHP操作csv文件导入+导出
    查看>>
    php操作mysql用select_php如何操作mysql获取select 结果
    查看>>
    PHP操作符与控制结构
    查看>>
    PHP支付宝SDK使用,电脑网页支付
    查看>>
    php支付宝手机网页支付类实例
    查看>>
    PHP改变数组key值的方法
    查看>>
    php教程之php空白页的原因及解决方法
    查看>>
    PHP数据库操作
    查看>>
    PHP数据文件过大,导致PHP加速器eaccelerator在PHP5.2版本下崩溃
    查看>>
    RabbitMQ - 死信、TTL原理、延迟队列安装和配置
    查看>>