Python实现迪杰斯特拉算法并生成最短路径的示例代码

yizhihongxing

下面是详细讲解“Python实现迪杰斯特拉算法并生成最短路径的示例代码”的完整攻略,包括算法原理、Python实现和两个示例说明。

算法原理

Dijkstra算法是一种用于查找图中最短路径的算法。其主要思想是从起点开始,逐步扩展到其他节点,直到到达终点。在扩展的过程中,记录每个节点的最短路径和前驱节点,最终得到起点到终点的最短路径。Dijkstra算法的实现过程如下:

  1. 初始化起点的最短路径为0,其他节点的最短路径为无穷大。
  2. 选择一个未标记的节点,计算该节点到起点的距离,并更新其邻居节点的最短路径和前驱节点。
  3. 标记该节点为已访问,重复步骤2,直到到达终点或所有节点都被标记为已访问。
  4. 根据每个节点的前驱节点,构建起点到终点的短路径。

Python实现

以下是Python实现Dijkstra算法的示例代码:

import heapq

def dijkstra(graph, start, end):
    distances = {vertex: float('inf') for vertex in graph}
    distances[start] = 0
    pq = [(0, start)]
    while pq:
        current_distance, current_vertex = heapq.heappop(pq)
        if current_vertex == end:
            path = []
            while current_vertex != start:
                path.append(current_vertex)
                current_vertex = previous_vertices[current_vertex]
            path.append(start)
            path.reverse()
            return path, current_distance
        if current_distance > distances[current_vertex]:
            continue
        for neighbor, weight in graph[current_vertex].items():
            distance = current_distance + weight
            if distance < distances[neighbor]:
                distances[neighbor] = distance
                previous_vertices[neighbor] = current_vertex
                heapq.heappush(pq, (distance, neighbor))
    return None

上述代码中使用Python实现了Dijkstra算法。首先定义了一个函数dijkstra,该函数接受一个图、起点和终点作为参数,返回起点到终点的最短路径和距离。在函数中,使用堆化的方式实现了Dijkstra算法。

示例说明

以下两个示例,说明如何使用上述代码进行最短路径查找。

示例1

使用Dijkstra算法查找一个简单图的最短路径。

graph = {
    'A': {'B': 1, 'C': 4},
    'B': {'A': 1, 'C': 2, 'D': 5},
    'C': {'A': 4, 'B': 2, 'D': 1},
    'D': {'B': 5, 'C': 1}
}

previous_vertices = {}
start = 'A'
end = 'D'
path, distance = dijkstra(graph, start, end)
print(f"最短路径为:{path},距离为:{distance}")

运行上述代码,输出结果为“最短路径为:['A', 'B', 'C', 'D'],距离为:4”。

上述代码中,使用Dijkstra算法查找一个简单图的最短路径。首先定义了一个图,起点和终点,并调用dijkstra函数计算最短路径和距离,最后输出结果。

示例2

使用Dijkstra算法查找一个复杂图的最短路径。

graph = {
    'A': {'B': 2, 'C': 3},
    'B': {'A': 2, 'C': 1, 'D': 4},
    'C': {'A': 3, 'B': 1, 'D':2, 'E': 3},
    'D': {'B': 4, 'C': 2, 'E': 1, 'F': 3},
    'E': {'C': 3, 'D': 1, 'F': 1},
    'F': {'D': 3, 'E': 1}
}

previous_vertices = {}
start = 'A'
end = 'F'
path, distance =jkstra(graph, start, end)
print(f"最短路径为:{path},距离为:{distance}")

运行上述代码,输出结果为“最短路径为:['A', 'B', 'D', 'F'],距离为:9”。

上述代码中,使用Dijkstra算法查找一个复杂图的最短路径。首先定义了一个图,起点和终点,并调用dijkstra函数计算最短路径和距离,最后输出结果。

结语

本文介绍了如何使用Python实现Dijkstra算法进行图的最短路径查找,包括算法原理、Python实现和两个示例说明。Dijkstra算法是一种用于查找图中最短路径的算法,其主要思想是从起点开始,逐步扩展到其他节点,直到到达终点。在实现中,需要注意选择适当的数据结构,并根据具体情况调整。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Python实现迪杰斯特拉算法并生成最短路径的示例代码 - Python技术站

(0)
上一篇 2023年5月14日
下一篇 2023年5月14日

相关文章

  • Python学习之while 循环语句

    Python学习之while 循环语句 什么是while循环? 在Python编程中,while循环是一种重复执行某个代码块的语句。只要指定的循环条件为True,循环就会一直执行下去。 while循环的语法 while循环的语法如下: while 循环条件: 循环体代码 其中,循环条件是一个布尔表达式,若为 True,则循环体代码将不断执行,直到循环条件变为…

    python 2023年5月31日
    00
  • Python实现生成简单的Makefile文件代码示例

    生成Makefile文件是软件开发中的一个重要环节。Python作为一门高级语言,能够轻松地实现Makefile文件的自动生成。本文将提供一个Python代码示例,展示如何生成一个简单的Makefile文件。下面是详细的攻略: 1. 安装Python 首先,确保你的电脑上已经安装了Python。你需要在官网上下载并安装Python 3.x版本,这里我们以Py…

    python 2023年6月5日
    00
  • Python多层嵌套list的递归处理方法(推荐)

    以下是详细讲解“Python多层嵌套list的递归处理方法(推荐)”的完整攻略。 在Python中,多层嵌套的列表(list)是一种常见的数据结构。在处理多层套的列表时,可以使用递归的方法来遍历和处理列表中的元素。下面是一些常见的递归处理方法。 方法一:使用递归函数 def process_list(lst): for item in lst: if isi…

    python 2023年5月13日
    00
  • Redis 如何进行哨兵模式(Sentinel)?

    以下是 Redis 如何进行哨兵模式(Sentinel)的完整使用攻略。 Redis 哨兵模式简介 Redis 哨兵模式是一种高可用性解决方案,可以自动监控 Redis 主节点和从节点的状态,并在主节点宕机时自动将从节点升级为主节点,以保证 Redis 服务的可用性。Redis 哨兵模式由多个 Redis 哨兵节点组成,每个 Redis 哨兵节点都可以监控多…

    python 2023年5月12日
    00
  • python中print的不换行即时输出的快速解决方法

    讲解“Python中print的不换行即时输出的快速解决方法”的完整攻略。本方法需要使用Python的sys和time库,步骤如下: 1. 导入库 首先需要导入sys和time库,这时Python就可以识别用于控制输出和延时的指令。 import sys,time 2. 输出字符串 使用sys.stdout.write()指令输出字符串,这个指令可以不换行地…

    python 2023年6月5日
    00
  • 关于Python两个列表进行全组合操作的三种方式

    以下是“关于Python两个列表进行全组合操作的三种方式”的完整攻略。 1. 全组合操作的概述 全组合操作是指将两个列表中的元素进行全排列组合,生成一个的列表。在Python中,我们可以使用三种方式来实现全组操作。 2. 方式一:使用itertools.product()函数 Python中的itertools模块提供了一个product()函数可以用来实现…

    python 2023年5月13日
    00
  • python基于plotly实现画饼状图代码实例

    下面我将详细讲解如何基于Python和Plotly库实现画饼状图的代码实例。 环境配置 在开始实现之前,需要先安装Plotly库。安装方法如下: pip install plotly 导入Plotly库 在代码实现前,需要先导入Plotly库的相关模块,如下所示: import plotly.graph_objs as go from plotly.offl…

    python 2023年5月19日
    00
  • Python正则表达式非贪婪、多行匹配功能示例

    Python正则表达式非贪婪、多行匹配功能示例 在Python正则表达式中,有两个非常有用的功能:非贪婪匹配和多行匹配。贪婪匹配指的是尽可能多地匹配字符,而不尽可能少地匹配字符;非贪婪匹配则相反,尽可能少地匹配字符。多行匹配指的是匹配多行文本,而不是单行文本。下面将分别介绍两个功能,并提供两个示例说明。 非贪婪匹配 在正则表达式中,*和+默认是贪的,即尽可能…

    python 2023年5月14日
    00
合作推广
合作推广
分享本页
返回顶部