当前位置: 首页 > news >正文

【图论】单源最短路问题

Dijkstra算法 -- 这是我职业生涯中唯一一个会写,却叫不上名字的算法

Dijkstra算法是一种单源最短路径算法,用于找出图中从一个源点到其他所有点的最短路径。该算法的原理是采用贪心策略,每次将距离源点最近的点加入到已确定最短路径的集合中,并更新其它节点的距离。具体实现过程如下:

  1. 初始化距离数组dist[],源点距离为0,其余点距离为无穷大。

  2. 将所有点加入到未确定最短路径的集合中。

  3. 在未确定最短路径的集合中找出距离源点最近的节点v,并将其加入到已确定最短路径的集合中。

  4. 对节点v的所有邻居节点u进行更新,如果dist[u] > dist[v] + w(v,u),则更新dist[u] = dist[v] + w(v,u),其中w(v,u)是v到u的边权值。

  5. 重复步骤3和4,直到所有节点都被加入到已确定最短路径的集合中。

Dijkstra算法的时间复杂度为O(V^2),其中V为节点数。如果使用优先队列来优化实现,时间复杂度可以优化到O(ElogV),其中E为边数。

relax -- 松弛操作

松弛操作是指在图论中,对某个节点的估计值进行更新的过程。通常用于单源最短路径算法,例如Dijkstra算法和Bellman-Ford算法中。具体来说,当我们使用Dijkstra算法或Bellman-Ford算法计算从源节点到其他节点的最短路径时,我们维护一个估计值列表,表示从源节点到每个节点的距离估计,随着算法的执行,我们逐步更新这个列表,直到找到最短路径。

对于Dijkstra算法,我们通过选择距离源节点最近的未标记节点来进行松弛操作,并更新源节点到该节点的距离估计值。以节点u为例,假设当前我们已经确定从源节点到节点u的距离估计值为d[u],而节点u有一个邻居节点v,且u和v之间有一条边e(u,v),边e(u,v)的权重为w(u,v),我们可以通过以下方式来更新v的距离估计值:

d[v] = min(d[v], d[u] + w(u,v))

其中,min表示取两个值的较小值,即如果u到v的距离比当前估计值更短,则更新d[v]为新的估计值。

对于Bellman-Ford算法,我们对所有的边进行松弛操作,直到不能再进行更新为止。以边e(u,v)为例,我们可以通过以下方式来更新v的距离估计值:

if d[u] + w(u,v) < d[v]:
    d[v] = d[u] + w(u,v)

其中,if语句的意思是,如果u到v的距离比当前估计值更短,则更新d[v]为新的估计值。

需要注意的是,Bellman-Ford算法可以处理负权边,而Dijkstra算法只适用于图中没有负权边的情况。

http://www.lryc.cn/news/116775.html

相关文章:

  • 物理层扩展以太网
  • Llama 2 with langchain项目详解(一)
  • IDEA全局设置MyBatis中写SQL语句提示
  • Linux 内存管理
  • oracle怎样给某个普通用户授予杀自己用户会话的权限
  • redis的主从复制,哨兵和cluster集群
  • Crowd-Robot Interaction 论文阅读
  • 什么是LIMS系统,LIMS实验室管理系统
  • Python Opencv实践 - 图像属性相关
  • PCB制造中铜厚度的重要性
  • 浅谈高校宿舍水电表远程智能管理的研究与应用
  • 无货源跨境电商购物平台快速搭建(微商城、小程序、APP、网站)
  • 力扣:57. 插入区间(Python3)
  • List和数组互转方法以及踩坑点
  • css3背景渐变
  • windows 安装免费3用户ccproxy ubuntu 代理上网
  • B树的插入与删除过程
  • 【二分】CF1623 C
  • redis五大类型分析--list(1)
  • 【多重信号分类】超分辨率测向方法——依赖于将观测空间分解为噪声子空间和源/信号子空间的方法具有高分辨率(HR)并产生准确的估计(Matlab代码实现)
  • 【Express.js】集成Websocket
  • MachineLearningWu_14/P65-P69_Multiclass
  • 深入理解高并发编程 - SimpleDateFormat 类的线程安全问题
  • 接口幂等性实现方式
  • redis高可用之持久化
  • Cocos Creator 3.8 后期效果 Shader 编写(2/2) 进阶篇
  • 【JS自用模板】自动点击选课的操作模板
  • TENNECO EDI 项目——X12与XML之间的转换
  • C++项目:在线五子棋对战(网页版)
  • flutter遇到的小问题记录