【图与网络数学模型】1.Dijkstra算法求解最短路径问题

2024-02-19 08:20

本文主要是介绍【图与网络数学模型】1.Dijkstra算法求解最短路径问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

【图与网络数学模型】1.Dijkstra算法求解最短路径问题

  • 一、图论基本概念
    • 1. 图论
    • 2. 哥尼斯堡七桥问題
    • 3. 图的一些基本概念
    • 4. 图的矩阵表示
  • 二、最短路径问题算法
    • 1. 图形的标号法
    • 2. Dijkstra法
      • (1)基本思路
      • (2)求解示例
  • 三、基于Python的Dijkstra算法
    • 1. 创建图对象
    • 2. 打印最短路径
    • 3. 查找顶点
    • 4. Dijkstra 算法实现
    • 5. 完整程序运行


一、图论基本概念

1. 图论

图论是应用非常广泛的运筹学分支,它已经广泛地应用于物理学控制论、信息论、工程技术、交通运输、经济管理、电子计算机等各项领域。对于科学研究、市场和社会生活中的许多问题,可以用图论的理论和方法来加以解决。

2. 哥尼斯堡七桥问題

关于图的第一篇论文是瑞士数学家欧拉(E. Euler)在1736年发表的解决“哥尼斯堡” 七桥难题的论文。

要如何走过每座桥恰一次,再返回出发点?

在这里插入图片描述

即能否从某一点开始不重复地一笔画出这个图形,最终回到原点。欧拉在他的论文中证明了这是不可能的,因为这个图形中每一个顶点都与奇数条边相连接,不可能将它一笔画出,这就是古典图论中的第一个著名问题。

3. 图的一些基本概念

图论中的图是由点、点与点之间的线所组成的。

涉及的一些概念如下表,在此不做赘述。

边,弧无向图
端点关联边有向图
始点,终点多重边简单图初等链/圈
度(次)多重图简单链/圈
奇点,偶点连通图基础图
悬挂点悬挂边不连通图
弧立点回路

4. 图的矩阵表示

邻接矩阵 Adjacency matrix

  • 表示图中两点之间的相互关系
  • 两点之间有弧或边的,用1表示,否则用0表示,构成一个矩阵A

在这里插入图片描述
上图可用矩阵表示如下:
在这里插入图片描述

二、最短路径问题算法

最短路径问题是图论中十分重要的最优化问题之一,它作为一个经常被用到的基本工具,可以解决生产实际中的许多问题,也可以用于解决其它的最优化问题。

如果P是D中从 v s v_s vs v i v_i vi 的最短路, v i v_i vi 是 P 中的一个点,那么从 v s v_s vs 沿 P 到 v i v_i vi 的路是从 v s v_s vs v i v_i vi 的最短路。

1. 图形的标号法

求下图从A到G的最短路:
在这里插入图片描述

解法:先标出离终点最近的一段,然后标号与该点距离最短的点,继续逆推至始点。

在这里插入图片描述

从A到G的最短路为: A - B1-C2-D1-E2-F2-G

2. Dijkstra法

(1)基本思路

v s v_s vs出发,逐步地向外探寻最短路。

执行过程中,与每个点对应,记录下一个数 (称为此点的标号)

  1. 它或者表示从 v s v_s vs到该点的最短路的权 (称为P标号)
  2. 或者是从 v s v_s vs到该点的最短路的权的上界 (称为T标号)

方法的每一步是修改T标号,并且把某一个具T标号的点改变为具P标号的点,从而使D中具P标号的点多一个,如此经过 p-1步,就可以求出从 v s v_s vs到各点的最短路。

(2)求解示例

例如求下图从1到8的最短路径:
在这里插入图片描述

  1. X={1}, w 1 w_1 w1=0
    在这里插入图片描述

  2. X={1,4}
    在这里插入图片描述

  3. X={1,2,4}
    在这里插入图片描述

  4. X={1,2,4,6}
    在这里插入图片描述

  5. X={1,2,4,6,7}
    在这里插入图片描述

  6. X={1,2,3,4,6,7}
    在这里插入图片描述

  7. X={1,2,3,4,6,7,8}
    在这里插入图片描述
    1到8的最短路径为{1,4,7,5,8},长度为10。

三、基于Python的Dijkstra算法

1. 创建图对象

创建一个图对象:接受一个参数 vertices,表示图中顶点的数量。

在初始化过程中,将顶点数量存储在 self.V 中,并创建一个二维数组 self.graph 作为邻接矩阵,初始值为0。

	def __init__(self, vertices):self.V = verticesself.graph = [[0 for column in range(vertices)]for row in range(vertices)]

2. 打印最短路径

printSolution(self, dist):接受一个参数 dist,该参数是一个包含各个顶点距离源点的最短距离的列表。

遍历所有顶点,打印每个顶点及其距离源点的最短距离。

	def printSolution(self, dist):print("Vertex \t Distance from Source")for node in range(self.V):print(node, "\t\t", dist[node])

3. 查找顶点

查找未包含在最短路径树中的距离源点最近的顶点。

minDistance(self, dist, sptSet):接受两个参数 dist 和 sptSet,分别表示从源点到各个顶点的当前最短距离和是否已经包含在最短路径树中。

遍历所有顶点,找到距离源点最近且未包含在最短路径树中的顶点,并返回其索引。

	def minDistance(self, dist, sptSet):min = 1e7for v in range(self.V):if dist[v] < min and sptSet[v] == False:min = dist[v]min_index = vreturn min_index

4. Dijkstra 算法实现

参数 src:表示源点的索引。

初始化距离源点的距离列表 dist 和最短路径树标记列表 sptSet。

在循环中,选择距离源点最近且未包含在最短路径树中的顶点作为当前顶点 u,将其标记为已经包含在最短路径树中。

更新与当前顶点相邻且未包含在最短路径树中的顶点的距离,如果新的距离小于之前记录的距离,则更新距离值。

最后调用 printSolution 方法打印结果。

	def dijkstra(self, src):dist = [1e7] * self.Vdist[src] = 0sptSet = [False] * self.Vfor cout in range(self.V):u = self.minDistance(dist, sptSet)sptSet[u] = Truefor v in range(self.V):if (self.graph[u][v] > 0 andsptSet[v] == False anddist[v] > dist[u] + self.graph[u][v]):dist[v] = dist[u] + self.graph[u][v]self.printSolution(dist)

5. 完整程序运行

求下图从1到8的最短路径:
在这里插入图片描述

class Graph():def __init__(self, vertices):self.V = verticesself.graph = [[0 for column in range(vertices)]for row in range(vertices)]def printSolution(self, dist):print("Vertex \t Distance from Source")for node in range(self.V):print(node, "\t\t", dist[node])def minDistance(self, dist, sptSet):min = 1e7for v in range(self.V):if dist[v] < min and sptSet[v] == False:min = dist[v]min_index = vreturn min_indexdef dijkstra(self, src):dist = [1e7] * self.Vdist[src] = 0sptSet = [False] * self.Vfor cout in range(self.V):u = self.minDistance(dist, sptSet)sptSet[u] = Truefor v in range(self.V):if (self.graph[u][v] > 0 andsptSet[v] == False anddist[v] > dist[u] + self.graph[u][v]):dist[v] = dist[u] + self.graph[u][v]self.printSolution(dist)g = Graph(8)
g.graph = [[0, 2, 0, 1, 0, 3, 0, 0],[0, 0, 6, 0, 5, 0, 0, 0],[0, 0, 0, 0, 0, 0, 0, 6],[0, 10, 0, 0, 0, 0, 2, 0],[0, 0, 9, 0, 0, 0, 0, 4],[0, 0, 0, 5, 0, 0, 4, 0],[0, 7, 0, 0, 3, 0, 0, 8],[0, 0, 0, 0, 0, 0, 0, 0]]g.dijkstra(0)

输出结果如下:

Vertex 	 Distance from Source
0 		 0
1 		 2
2 		 8
3 		 1
4 		 6
5 		 3
6 		 3
7 		 10

1-8最短路径的长度为10.

这篇关于【图与网络数学模型】1.Dijkstra算法求解最短路径问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

解决IDEA报错:编码GBK的不可映射字符问题

《解决IDEA报错:编码GBK的不可映射字符问题》:本文主要介绍解决IDEA报错:编码GBK的不可映射字符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录IDEA报错:编码GBK的不可映射字符终端软件问题描述原因分析解决方案方法1:将命令改为方法2:右下jav

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

《MyBatis模糊查询报错:ParserException:notsupported.pos问题解决》本文主要介绍了MyBatis模糊查询报错:ParserException:notsuppo... 目录问题描述问题根源错误SQL解析逻辑深层原因分析三种解决方案方案一:使用CONCAT函数(推荐)方案二:

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

Redis 热 key 和大 key 问题小结

《Redis热key和大key问题小结》:本文主要介绍Redis热key和大key问题小结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、什么是 Redis 热 key?热 key(Hot Key)定义: 热 key 常见表现:热 key 的风险:二、

IntelliJ IDEA 中配置 Spring MVC 环境的详细步骤及问题解决

《IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决》:本文主要介绍IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决,本文分步骤结合实例给大... 目录步骤 1:创建 Maven Web 项目步骤 2:添加 Spring MVC 依赖1、保存后执行2、将新的依赖

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

Spring 中的循环引用问题解决方法

《Spring中的循环引用问题解决方法》:本文主要介绍Spring中的循环引用问题解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录什么是循环引用?循环依赖三级缓存解决循环依赖二级缓存三级缓存本章来聊聊Spring 中的循环引用问题该如何解决。这里聊

Spring Boot中JSON数值溢出问题从报错到优雅解决办法

《SpringBoot中JSON数值溢出问题从报错到优雅解决办法》:本文主要介绍SpringBoot中JSON数值溢出问题从报错到优雅的解决办法,通过修改字段类型为Long、添加全局异常处理和... 目录一、问题背景:为什么我的接口突然报错了?二、为什么会发生这个错误?1. Java 数据类型的“容量”限制

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring