Dijkstra(迪克斯特拉)最短路径算法

2024-02-15 15:20

本文主要是介绍Dijkstra(迪克斯特拉)最短路径算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、算法思想:设G=(V,E)是一个带权有向图,把图中顶点集合V分成两组,第一组为已求出最短路径的顶点集合(用S表示,初始时S中只有一个源点,以后每求得一条最短路径 ,就将加入到集合S中,直到全部顶点都加入到S中,算法就结束了),第二组为其余未确定最短路径的顶点集合(用U表示),按最短路径长度的递增次序依次把第二组的顶点加入S中。在加入的过程中,总保持从源点v到S中各顶点的最短路径长度不大于从源点v到U中任何顶点的最短路径长度。此外,每个顶点对应一个距离,S中的顶点的距离就是从v到此顶点的最短路径长度,U中的顶点的距离,是从v到此顶点只包括S中的顶点为中间顶点的当前最短路径长度。

2、算法步骤:

a.初始时,S只包含源点,即S={v},v的距离为0。U包含除v外的其他顶点,即:U={其余顶点},若v与U中顶点u有边,则<u,v>正常有权值,若u不是v的出边邻接点,则<u,v>权值为∞。

b.从U中选取一个距离v最小的顶点k,把k,加入S中(该选定的距离就是v到k的最短路径长度)。

c.以k为新考虑的中间点,修改U中各顶点的距离;若从源点v到顶点u的距离(经过顶点k)比原来距离(不经过顶点k)短,则修改顶点u的距离值,修改后的距离值的顶点k的距离加上边上的权。

d.重复步骤b和c直到所有顶点都包含在S中。

3、举例分析。

步骤S集合U集合
1

以A为源点,此时S={A}

最短路径:A\rightarrowA=0

以A为中间点,从A开始找

U={B、C、D、E、F}

A\rightarrowB=6

A\rightarrowC=3

A\rightarrowU中其它顶点=\infty

A\rightarrowC=3最短

2

将C加入S中,S={A、C}

最短路径:A\rightarrowA=0,A\rightarrowC=3

以C为中间点,从A\rightarrowC=3这条最短路径开始找

U={B、D、E、F}

A\rightarrowC\rightarrowB=5(比上一步的A\rightarrowB=6短)

A\rightarrowC\rightarrowD=6

A\rightarrowC\rightarrowE=7

A\rightarrowC\rightarrowU中其它顶点=\infty

A\rightarrowC\rightarrowB=5最短

3

将B加入S中,S={A、C、B} 

最短路径:A\rightarrowA=0,A\rightarrowC=3、A\rightarrowC\rightarrowB=5

以B为中间点,从A\rightarrowC\rightarrowB=5这条最短路径开始找

U={D、E、F}

A\rightarrowC\rightarrowB\rightarrowD=10(比第二步中的A\rightarrowC\rightarrowD=6长,所以将D的权值更改为A\rightarrowC\rightarrowD=6)

A\rightarrowC\rightarrowB\rightarrowU中其它顶点=\infty

A\rightarrowC\rightarrowD=6最短

4

将D加入S中,S={A、C、B、D} 

最短路径:A\rightarrowA=0,A\rightarrowC=3、A\rightarrowC\rightarrowB=5、A\rightarrowC\rightarrowD=6

以D为中间点,从A\rightarrowC\rightarrowD=6这条最短路径开始找

U={E、F}

A\rightarrowC\rightarrowD\rightarrowE=8(比第二步中的A\rightarrowC\rightarrowE=7长,所以将E的权值更改为A\rightarrowC\rightarrowE=7)

A\rightarrowC\rightarrowD\rightarrowF=9

A\rightarrowC\rightarrowE=7最短

5

将E加入S中,S={A、C、B、D、E} 

最短路径:A\rightarrowA=0,A\rightarrowC=3、A\rightarrowC\rightarrowB=5、A\rightarrowC\rightarrowD=6、A\rightarrowC\rightarrowE=7

以E为中间点,从A\rightarrowC\rightarrowE=7这条最短路径开始找

U={F}

A\rightarrowC\rightarrowE\rightarrowF=12(比第四步中的A\rightarrowC\rightarrowD\rightarrowF=9长,所以将F的权值更改为A\rightarrowC\rightarrowD\rightarrowF=9)

A\rightarrowC\rightarrowD\rightarrowF=9最短

6

将F加入S中,S={A、C、B、D、E、F} 

最短路径:A\rightarrowA=0,A\rightarrowC=3、A\rightarrowC\rightarrowB=5、A\rightarrowC\rightarrowD=6、A\rightarrowC\rightarrowE=7、A\rightarrowC\rightarrowD\rightarrowF=9

U集合为空,所有点的最短路径查找完毕。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

四、matlab代码

function[dist priorVertex]=Dijkstra(w,start,terminal)
w=[0 6 3 inf inf inf;inf 0 inf 5 inf inf;inf 2 0 3 4 inf;inf inf inf 0 2 3;inf inf inf inf 0 5;inf inf inf inf inf inf];n=size(w,1);w1=w(1,:);V=1:n;%赋初值for i=1:ndist(i)=w1(i);%辅助数组dist。它的每一个分量dist[i]表示当前找到的从源点v1到顶点vi的最短路径的长度。priorVertex(i)=1;endS=[]S(1)=1;u=S(1);%更新前驱顶点k=1;while k<n%求V1到其余各顶点的最短距离%更新dist(v)和priorVertex(v)Sdiff=setdiff(V,S)%求V-S差集for i=Sdiffif dist(i)>dist(u)+w(u,i)%距离有变化的修正dist(i)=dist(u)+w(u,i);priorVertex(i)=u;endend%求v*v=Sdiff(1);m=length(Sdiff);for i=2:m;if dist(v)>dist(Sdiff(i))v=Sdiff(i);endendk=k+1;S(k)=v;%更新前驱顶点u=v;enddisp('最终V1到各个顶点的最短距离分别为:')distdisp('最终各个顶点的直接前驱分别为:')priorVertex

 

这篇关于Dijkstra(迪克斯特拉)最短路径算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/711773

相关文章

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

python获取当前文件和目录路径的方法详解

《python获取当前文件和目录路径的方法详解》:本文主要介绍Python中获取当前文件路径和目录的方法,包括使用__file__关键字、os.path.abspath、os.path.realp... 目录1、获取当前文件路径2、获取当前文件所在目录3、os.path.abspath和os.path.re

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

hdu2544(单源最短路径)

模板题: //题意:求1到n的最短路径,模板题#include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#i

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

poj 3974 and hdu 3068 最长回文串的O(n)解法(Manacher算法)

求一段字符串中的最长回文串。 因为数据量比较大,用原来的O(n^2)会爆。 小白上的O(n^2)解法代码:TLE啦~ #include<stdio.h>#include<string.h>const int Maxn = 1000000;char s[Maxn];int main(){char e[] = {"END"};while(scanf("%s", s) != EO

poj 1502 MPI Maelstrom(单源最短路dijkstra)

题目真是长得头疼,好多生词,给跪。 没啥好说的,英语大水逼。 借助字典尝试翻译了一下,水逼直译求不喷 Description: BIT他们的超级计算机最近交货了。(定语秀了一堆词汇那就省略吧再见) Valentine McKee的研究顾问Jack Swigert,要她来测试一下这个系统。 Valentine告诉Swigert:“因为阿波罗是一个分布式共享内存的机器,所以它的内存访问