不修改原始节点的情况下编写Dijkstra算法的代码
创始人
2025-01-10 10:30:29
0

在不修改原始节点的情况下编写Dijkstra算法的代码可以使用优先级队列(Priority Queue)来实现。

以下是一个示例代码:

import heapq

def dijkstra(graph, start):
    # 初始化距离字典,用于存储起始节点到其他节点的距离
    distances = {node: float('inf') for node in graph}
    distances[start] = 0
    
    # 创建优先级队列,用于存储节点及其到起始节点的距离
    queue = [(0, start)]
    
    while queue:
        current_distance, current_node = heapq.heappop(queue)
        
        # 如果当前节点已经被处理过,则跳过
        if current_distance > distances[current_node]:
            continue
        
        # 遍历当前节点的所有邻居节点
        for neighbor, weight in graph[current_node].items():
            distance = current_distance + weight
            
            # 如果找到更短的路径,则更新距离字典和优先级队列
            if distance < distances[neighbor]:
                distances[neighbor] = distance
                heapq.heappush(queue, (distance, neighbor))
    
    return distances

使用示例:

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

distances = dijkstra(graph, 'A')
print(distances)

该代码使用了一个优先级队列来存储节点及其到起始节点的距离。在每次迭代中,从队列中弹出当前距离最小的节点,然后更新其邻居节点的距离。如果找到更短的路径,则更新距离字典和优先级队列。最终返回距离字典,其中包含了起始节点到所有其他节点的最短距离。

相关内容

热门资讯

黑科技能赢(微扑克ai辅助器)... 黑科技能赢(微扑克ai辅助器)太嚣张了一向有挂(透视)详细教程(2022已更新)(哔哩哔哩)微扑克a...
黑科技实锤(wepoke透明挂... 黑科技实锤(wepoke透明挂辅助)太实锤了从来真的有挂(透视)系统教程(2022已更新)(哔哩哔哩...
黑科技真的(德州之星辅助器使用... 黑科技真的(德州之星辅助器使用教程)太嚣张了一贯存在有挂(透视)科技教程(2020已更新)(哔哩哔哩...
黑科技好牌(wepoke有假吗... 黑科技好牌(wepoke有假吗)太坑了固有真的是有挂(透视)德州教程(2025已更新)(哔哩哔哩)是...
黑科技苹果版(aapoker俱... 黑科技苹果版(aapoker俱乐部后台可以操作吗)太坑了本来存在有挂(透视)安装教程(2026已更新...
黑科技ai代打(德扑之星代打)... 黑科技ai代打(德扑之星代打)太坑了起初是有挂(透视)可靠教程(2020已更新)(哔哩哔哩)1)德扑...
黑科技ai(wepower让系... 黑科技ai(wepower让系统发好牌)太夸张了一直是真的有挂(透视)细节方法(2025已更新)(哔...
黑科技插件(wepower透视... 黑科技插件(wepower透视辅助使用方法)太离谱了本来有挂(透视)分享教程(2023已更新)(哔哩...
黑科技app(aapoker有... 黑科技app(aapoker有外挂吗)太坑了都是是真的有挂(透视)新版2025教程(2020已更新)...
黑科技安装(wpk长期盈利打法... 黑科技安装(wpk长期盈利打法教学)太离谱了本来存在有挂(透视)分享教程(2022已更新)(哔哩哔哩...