已知带权有向图如图7-29所示,请利用Dijkstra算法从顶点V4出发到其余顶点的最短路

作者&投稿:代狄 (若有异议请与网页底部的电邮联系)
利用Dijkstra算法求下图中从顶点1到其它各顶点间的最短路径,按下面表格形式~

v1到v2:10为最短路径;
v1到v3:7为最短路径;
v1到v4:8为最短路径;
v1到v5:v1-> v2 -> v5 =10+6= 16;v1v3v5=7+9=16;v1v4v6v5=8+5+2=15; 15为最短路径;
v1到v6:v1v2v3v6=10+2+9=21;v1v3v6=7+9=16;v1v4v6=8+5=13;13为最短路径;
v1到v7:v1v2v5v7=10+6+20=36;v1v3v5v7=7+9+20=36;v1v3v6v7=7+9+30=46;
v1v4v6v7=8+5+30=42;v1v4v6v5v7=35;35为最短路径

Dijkstra:
求单源、无负权的最短路。时效性较好,时间复杂度为O(V*V+E)。源点可达的话,O(V*lgV+E*lgV)=>O(E*lgV)。当是稀疏图的情况时,此时E=V*V/lgV,所以算法的时间复杂度可为O(V^2)。若是斐波那契堆作优先队列的话,算法时间复杂度,则为O(V*lgV + E)。
以上内容参考:百度百科-最短路径算法

我用自己写的软件运行了一下,只截图顶点1到顶点8吧,橙色线就是最短路径了。


其实从图就不难看出答案,1-5-6-7-4-8。这也是1到各顶点5,6,7,4,8的各点最短路径。
如果顶点1到顶点3就是1-5-6-7-3.

初始化d[i]为无穷大,由于从v4开始,所以将d4=0,标记v4已选择。
下面开始Dijkstra算法:
和v4相连的且未标记的点有v2和v6,这样更新d2=20,d6=15,选择未标记所有点中最小的d6=15,标记v6已选择,这样我们算出了v4->v6最短距离d6=15;
从v6开始,和v6相连的且未标记的是v2,此时算d6+6=21>20,所以不更新d2,选择未标记所有点中最小的d2=20,标记v2已选择,这样算出了v4->v2最短距离d2=20;
从v2开始,和v2相连的且未标记的有v1和v5,d1=d2+10=30,d5=d2+30=50,选择未标记所有点中最小的d1=30,标记v1已选择,这样我们算出了v4->v1最短距离d1=30;
从v1开始,和v1相连的且未标记的有v3,d3=d1+15=45,选择剩下没被选的所有点的最小的d3=45(d5=50),标记v3已选择,这样我们算出了v4->v3最短距离d3=45
从v3开始,没有出去的路径,不更新距离,选择剩下没被选的所有点的最小的d5=50,标记v5已选择,这样我们算出了v4->v5最短距离d5=50.
此时所有的点都被访问,结束。
注:上面的标记点已选择注意下,在算法的实现中用的是将所有的点放入队列中,一旦一个点被选择就是说求出了最短距离,就从此队列删除该点,一直到此队列为空,结束算法,我写标记只是为了方便理解。
希望能帮你清晰了解Dijkstra算法,图论中很重要的算法之一。


AOE网AOE网(Activity On Edge Network)
在当今的现代管理中,一种常用的工具是带权有向图,它被广泛应用于工程计划和执行的可视化分析。一项复杂的工程项目常常被分解为多个独立的部分,这些部分被称为活动,通常用符号"Activity"表示。在AOE(Activity On Edge Network)图中,这种图形结构以顶点(Vertices)代表事件或里程碑,有向边(Directed ...

带权有向图中每个顶点的度怎么理解
带权有向图中每个顶点的度怎么理解方法;因为与顶点连通的顶点可能是相邻的顶点,也可能是相邻的相邻的顶点。连通指的是两个顶点之间有路径,若一个图是连通的,则和任意一个顶点连通的顶点数位N-1,N为图的顶点总数。顶点的度指的是与该顶点相关联的边的总数。两个顶点相邻指的是该两个顶点之间有...

想求遍历带权有向图所有边的最短通路 边可以重复走 只要全部遍历_百度...
一笔画问题 使除了两个结点外,所有结点的出度等于入度,剩下的两个结点,一个是始点,出度比入度大1,一个是终点,入度比出度大1 这样就需要增加一些边,使得增加的边的权重最小

C++实现数据结构 某带权有向图G
在解决这个问题之前,请你务必弄清这么几个问题:1、有向图 2、有向图的构造(由边、权的构造)3、有向图的邻接矩阵 4、有向图的拓扑序列 5、图的最短路径 在有高人回答之后,给我留言解释,谢谢

带权值的有向图和网的关系
区别是带不带“权”也就是权值 无向网是有的 而无向图是没有的 类似的有向网和有向图。有\/无 向图如果给图的每条边规定一个方向,那么得到的图称为有向图,其边也称为有向边。在有向图中,与一个节点相关联的边有出边和入边之分,而与一个有向边关联的两个点也有始点和终点之分。相...

OSPF如何通过LSDB生成带权有向图
没怎么看懂你的意思?spf算法是根据lsdb来算出自己去往目的的地址的,同意区域内的ospf路由器的lsdb是一样的,spf算法就是根据lsdb这个”地图”来构建最短路径树,这样因为树是没有环路的,所以ospf不必和eigrp和rip一样有那么多机制防止环路

数据结构个带权有向图表示某一区域的公交线路网,编译有错,求解
改一下主程序就行了 void main(){int vexnum;int cost[5][20];printf("构造一个图: ");vexnum=creatcost(&cost[0]);printf("\\n求最短路径:");dijkstra(&cost[0],vexnum);}

单源最短路径问题描述
在计算机科学中,有一个重要的图论问题被称作单源最短路径问题。这个问题涉及到一个带权的有向图 G,其结构由顶点集 V 和边集 E 组成。每个边在图中都有一个非负的权重,这些权重代表了从一个顶点到另一个顶点的实际距离或者成本。特别地,我们有一个特殊的顶点,称为源点。目标是计算从这个源...

带权邻接矩阵图的邻接矩阵表示法
邻接矩阵的每个元素w ij ,若表示边的权值,则可能是一个给定的整数;若仅表示边的存在与否,EdgeType可以定义为0或1的枚举类型。例如,无向图G 5 和有向图G 6 的邻接矩阵可以通过输入顶点数和边的信息来构建,如图A 1 和A 2。对于网络,邻接矩阵的定义会包含权值,其中w ij 代表边的权重,而...

运筹学有向图的名词解释是什么
首先你要知道有向图的定义 有向图是一个二元组<V,E>,其中 1.V是非空集合,称为顶点集。2.E是V×V的子集,称为弧集。运筹学的有向图都是带权的,所以在此基础上存在函数F:E |-> R^+,使得对于任意e∈E,存在w∈R^+,f(e)=w.其中R^+表示正实数 ...

会同县19115415842: 已知带权有向图如图所示,画出该图的邻接矩阵存储结构.
底翠达体: ∞ 2 ∞ 6 ∞ 9 ∞ ∞∞ ∞ 30 1 ∞ ∞ ∞ ∞∞ ∞ ∞ ∞ ∞ ∞ ∞ 5∞ ∞ ∞ ∞ 2 ∞ ∞ ∞∞ ∞ 8 ∞ ∞ ∞ 7 ∞∞ ∞ ∞ ∞ 3 ∞ 24 ∞∞ ∞ ∞ ∞ ∞ ∞ ∞ 21∞ ∞ ∞ ∞ ∞ ∞ ∞ ∞

会同县19115415842: 最优二叉树算法的基本概念 -
底翠达体: 最优二叉树,也称哈夫曼(Haffman)树,是指对于一组带有确定权值的叶结点,构造的具有最小带权路径长度的二叉树.那么什么是二叉树的带权路径长度呢?在前面我们介绍过路径和结点的路径长度的概念,而二叉树的路径长度则是...

会同县19115415842: 求有向图两个顶点间的最短路径的方法,用简单语言或举例描述. -
底翠达体:[答案] 在交通网络中,常常会提出许多这样的问题:两地之间是否有路相通?在有多条通路的情况下,哪一条最近?哪一条花费最少等.交通网络可以用带权图表示,图中顶点表示域镇,边表示两城之间的道路,边上权值可表示两城镇间的距离,交通费用或...

会同县19115415842: ...逐个输入各个数据而生成的二叉搜索树,并求出在等概率下的平均查找长度.搜索成功的平均搜索长度是指搜索到树中已有数据的平均探查次数.7.一个... -
底翠达体:[答案] A:10 B:001 C:11 D:0001 E:0110 F:0111 G:010 H:0000第二题:| | 12 | 100 | 25 | | 16 | 17 | 18 | 8 | 40 | 70 1 2 3 4 5 6 7 8 9 10

会同县19115415842: 有一个顶点编号为0~4的带权有向图G,现用Floyd算法求任意两个顶点...
底翠达体:[答案] 答:AD是∠BAC的平分线.∵∠B+∠BAD=∠EDA,∠EAD-∠EAC=∠DAC且∠EAD=∠EDA.∠EAC=∠B∴∠BAD=∠EDA-∠B∴∠BAD=∠DAC∴AD是∠BAC的平分线这题的图好像是如下图所示的这样:

会同县19115415842: 3、所谓一笔画是指从图的一点出发,经过图中每边一次且仅一次到达另...
底翠达体:[答案] 二、判断对错题:(每题2分,共40分,正确的选A,错误的选B) 1.\x05数据的逻辑结构是指数据的各数据项之间的逻辑关... B 33.\x05带权的有向图和无向图,只能使用邻接表存储形式来存储它.B 34.\x05适用于折半查找的表的存储方式及元素排列要...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网