迪杰斯特拉(Dijkstra)算法

一、迪杰斯特拉 **--**算法思想

按从某顶点到其它顶点的路径长度递增的方式,逐渐求到各顶点的最短路径。

设给定源点为Vs,S为已求得最短路径的终点集,开始时令S={Vs} 。当求得第一条最短路径(Vs,Vi)后,S为{Vs,Vi} 。根据以下结论可求下一条最短路径。

设下一条最短路径终点为Vj,则Vj只有:

源点到终点有直接的弧<Vs,Vj>;

从Vs出发到Vj的这条最短路径所经过的所有中间顶点必定在S中。即只有这条最短路径的最后一条弧才是从S内某个顶点连接到S外的顶点Vj**。**

若定义一个数组dist[n],其每个dist[i]分量保存从Vs出发中间只经过集合S中的顶点而到达Vi的所有路径中长度最小的路径长度值,则下一条最短路径的终点Vj必定是不在S中且值最小的顶点,即:

dist[i]=Min{ dist[k]| Vk∈V-S }

利用上述公式就可以依次找出下一条最短路径。

二、迪杰斯特拉 **算法--**数据组织


数据源
已确定结点集 S
待选结点集 V-S
结点临时最短路径长度
结点临时最短路径

三、迪杰斯特拉**算法---**步骤

令S={Vs} ,用带权的邻接矩阵表示有向图,对图中每个顶点Vi按以下原则置初值:

选择一个顶点Vj ,使得:

Distance[j]=Min{ Distance[k]| Vk∈V-S }

Vj就是求得的下一条最短路径终点,将Vj 并入到S中,即S=S∪{Vj} 。

对V-S中的每个顶点Vk ,修改dist[k],方法是:

Distance[j]+Wjk<Distance[k],则修改为:

Distance[k]=Distance[j]+Wjk ("Vk∈V-S )

重复②,③,直到S=V为止。

四、迪杰斯特拉**算法---**实现

cpp 复制代码
void Dijkstra(MGraph g,int start, int end)
{
    int dist[MAXV], path[MAXV];
    int s[MAXV];
    int mindis, i, j, u;
    for(i = 0; i < g.n; i ++)
    {
        dist[i] = g.edges[start][i];//dist数组初始化
        s[i] = 0;
        if(g.edges[start][i] < INF) 
			path[i] = start;
        else 
			path[i] = -1;        // path数组初始化
    } 
    s[start] = 1;                       //顶点start加入顶点集合s
	path[start] = 0;

    for(i = 0; i < g.n; i ++)//选择不在集合s中且具有最短路径的顶点
    {
        mindis = INF;
        for(j = 0; j < g.n; j ++)
        {
            if(s[j] == 0 && dist[j] < mindis)
            {
                u = j;
                mindis = dist[j];
            }    
        }    
s[u] = 1;//将顶点u加入集合
        for (j = 0; j < g.n; j ++)//修改dist和path
        {
            if (s[j] == 0)
            {
				if ((g.edges[u][j] < INF) && (dist[u] + g.edges[u][j] < dist[j]))
                {
                    dist[j] = dist[u] + g.edges[u][j];
                    path[j] = u;
                }    
            }    
        }    
    } 
    Dispath(g, dist, path, s, g.n, start, end);     
} 

**五、Dijkstra算法--**数据组织

**六、Dijkstra算法---**例子

**七、Dijkstra算法---**算法分析

Dijkstra算法的主要执行是:

**◆**数组变量的初始化:时间复杂度是O(n) ;

求最短路径的二重循环:时间复杂度是O(n2**) ;**

因此,整个算法的时间复杂度是O(n2) 。

0利用Dijkstra算法填写表格求图中从顶点a****到其他各顶点间的最短路径,并写出最终结果。

|---------|----|---|----|----|---|----|--------|
| 终点 Dist | b | c | D | e | f | g | S(终点集) |
| k=1 | 15 | 2 | 12 | ∞ | ∞ | ∞ | c |
| k=2 | 15 | | 12 | 10 | 6 | ∞ | C,f |
| k=3 | 15 | | 11 | 10 | | 16 | C,e,f |
| k=4 | | | | | | | |
| k=5 | | | | | | | |
| k=6 | | | | | | | |

相关推荐
安忘1 小时前
LeetCode 热题 -189. 轮转数组
算法·leetcode·职场和发展
Y1nhl1 小时前
力扣hot100_二叉树(4)_python版本
开发语言·pytorch·python·算法·leetcode·机器学习
曼诺尔雷迪亚兹2 小时前
2025年四川烟草工业计算机岗位备考详细内容
数据结构·数据库·计算机网络·算法
蜡笔小新..3 小时前
某些网站访问很卡 or 力扣网站经常进不去(2025/3/10)
算法·leetcode·职场和发展
Simon523143 小时前
数据结构---八大排序
java·数据结构·排序算法
IT猿手3 小时前
2025最新群智能优化算法:基于RRT的优化器(RRT-based Optimizer,RRTO)求解23个经典函数测试集,MATLAB
开发语言·人工智能·算法·机器学习·matlab
刘大猫263 小时前
五、MyBatis的增删改查模板(参数形式包括:String、对象、集合、数组、Map)
人工智能·算法·智能合约
修己xj4 小时前
算法系列之深度/广度优先搜索解决水桶分水的最优解及全部解
算法
_GR4 小时前
2019年蓝桥杯第十届C&C++大学B组真题及代码
c语言·数据结构·c++·算法·蓝桥杯
WW_千谷山4_sch4 小时前
MYOJ_4204:迷宫(图论-网格图基础,dfs,bfs在网格图中应用)
数据结构·c++·深度优先·图论·广度优先