图论——最短路Dijkstra算法

Dijkstra算法:给定一个源点,求解从源点到每个点的最短路径长度。单源最短路径算法。

适用范围:有向图边的权值没有负数

普通堆实现的Dijkstra算法最普遍、最常用:

a.节点弹出过就忽略

b.节点没弹出过,让其它没弹出 节点距离变小的记录加入堆
普通堆实现的Dijkstra算法,时间复杂度o(m*1ogm),m为边数

1,distance[i]表示从源点到i点的最短距离,visited[i]表示i节点是否从小根堆弹出过

2,准备好小根堆,小根堆存放记录:(x点,源点到x的距离),小根堆根据距离组织

3,令distance[源点]=0,(源点,0)进入小根堆

4,从小根堆弹出(u点,源点到u的距离)

a.如果visited[u]=true,不做任何处理,重复步骤4

b.如果visited[u]=false,令visited[u]=true,u就算弹出过了

然后考察u的每一条边,假设某边去往v,边权为w

  1. 如果visited[v]== false并且distance[u]+ w <distance[v]

令distance[v]= distance[u] + w,把(v,distance[u]+ w)加入小根堆

2)处理完u的每一条边之后,重复步骤4

5,小根堆为空过程结束,distance表记录了源点到每个节点的最短距离。

相关推荐
BirdenT1 小时前
20260519紫题训练
c++·算法
csdn_aspnet6 小时前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
谙弆悕博士6 小时前
【附C源码】从零实现C语言堆数据结构:原理、实现与应用
c语言·数据结构·算法··数据结构与算法
gaosushexiangji9 小时前
DIC系统推荐:基于千眼狼三维数字图像相关的无人机旋翼疲劳试验全场应变与位移测量
人工智能·算法
小王C语言11 小时前
【线程概念与控制】:线程封装
jvm·c++·算法
kyle~11 小时前
工程数学---点云配准卡布施(Kabsch)算法(求解最优旋转矩阵)
线性代数·算法·矩阵
张二娃同学12 小时前
03_变量常量与输入输出_printf与scanf详解
算法
江南十四行12 小时前
并发编程(一)
java·jvm·算法
z2005093012 小时前
今日算法(依旧二叉树)
算法·leetcode·职场和发展
Zxc_13 小时前
《遗传算法:从自然选择到Rastrigin函数优化,手写一个完整的进化求解器》
算法