剧情背景
在《庆余年 2》22集中,林相跟大宝交代完为人处世的人生哲理之后,就要跟大宝告别了
在《庆余年 2》23集中,林相在告老还乡的路上与婉儿和大宝告别后
范闲也在与婉儿的对话中知道黑骑调动是绝密,并把最近一次告老还乡梅执礼被马匪截杀与黑骑调动日期关联在一起,范闲知道了老皇帝要杀林相消息,所以范闲必须尽快找到一条最短路径在黑骑到之前去营救林相。这时候范闲在另外一个世界带来的记忆突然奔袭而来,马上想到用于地图导航GPS的Dijkstra算法,得找到路程最短的路径赶在黑骑到达前才能拯救林相,而在此之前他早就把庆国地形和路径都让人探究清楚了。知道黑骑所在位置到林相的位置大概需要75分钟。
现状输入描述
- 起点A:范闲目前所在的位置。
- 中点B:林相目前所在的位置。
- 节点集:A和B之间的多个节点路口CDEGF(例如路上的交叉点、村庄等)。
- 路程:连接这些节点的道路,每条道路有对应的行驶时间。
使用Dijkstra算法求解最短路径
实现原理
- Dijkstra 算法从指定的节点(源节点)出发,寻找它与图中所有其它节点之间的最短路径。
- Dijkstra 算法会记录当前已知的最短路径,并在寻找到更短的路径时更新。
- 一旦找到源节点与其他节点之间的最短路径,那个节点会被标记为“已访问”并添加到路径中。
- 重复寻找过程,直到图中所有节点都已经添加到路径中。这样,就可以得到从源节点出发访问所有其他节点的最短路径方案。
以下是详细的步骤和计算过程:
步骤 1: 初始化
- 起点A到所有其他节点的初始距离设为无穷大,除了起点本身,其距离为0。
- 使用优先队列初始化,从起点A开始。
距离:
A: 0
C: ∞
D: ∞
E: ∞
F: ∞
G: ∞
B: ∞
优先队列:
[(0, 'A')]
步骤 2: 处理节点A
- 从A出发,可以到C和D,更新距离。
步骤 3: 处理节点C
- 从C出发,可以到E,更新距离。
步骤 4: 处理节点D
- 从D出发,可以到E,但已有更短路径 C -> E,不更新。
距离:
A: 0
C: 15
D: 20
E: 25
F: ∞
G: ∞
B: ∞
优先队列:
[(