栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

开始,Dijkstra:打印出路径,而不仅仅是计算最短距离

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

开始,Dijkstra:打印出路径,而不仅仅是计算最短距离

当您在此处调整新路径距离时

   if D[edge.Destination] > D[edge.Source]+edge.Weight {      D[edge.Destination] = D[edge.Source] + edge.Weight

设置一些数组元素(例如,

P
对于“ parent”)以指出您
Destination
来自
Source

P[edge.Destination] = edge.Source

算法结束后,在此数组中,每个顶点将在从起始顶点开始的路径上具有其前身。

PS。好的,不适合数组和索引…

Prev
在“顶点”中添加一个新字段:

type Vertex struct {    Id      string    Visited bool    AdjEdge []*Edge    Prev *Vertex}

调整距离时:

if D[edge.Destination] > D[edge.Source]+edge.Weight {    D[edge.Destination] = D[edge.Source] + edge.Weight    edge.Destination.Prev = edge.Source

当您显示结果时:

for vertex1, distance1 := range distmap1 {    fmt.Println(vertex1.Id, "=", distance1)    if vertex1.Prev != nil {        fmt.Println (vertex1.Id, " -> ", vertex1.Prev.Id)    }}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/436331.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号