bellman ford
创始人
2024-03-12 05:05:58
0
package mainimport "fmt"// bellman ford 算法计算单源点到其他点的距离,它无法处理含有负权回路的图
func main() {type edge struct {from, to, weight int}graphs := []edge{{from: 0, to: 1, weight: 6},{from: 1, to: 2, weight: -2},{from: 0, to: 2, weight: 3},{from: 2, to: 3, weight: 5},{from: 3, to: 1, weight: 7},}max := 0x3f3f3f3fdistance := make([]int, len(graphs))m := len(graphs)     // 边数, 暂时手动设置n := len(graphs) - 1 // 顶点数, 暂时手动设置for i := 0; i < n; i++ {distance[i] = max}distance[0] = 0 // 自己到自己的距离是0for i := 0; i < n; i++ {for j := 0; j < m; j++ {if distance[graphs[j].from] < max {distance[graphs[j].to] = min(distance[graphs[j].to], distance[graphs[j].from]+graphs[j].weight)}}}flag := falsefor i := 0; i < n; i++ {if distance[graphs[i].to] > distance[graphs[i].from]+graphs[i].weight {flag = true}}if flag {fmt.Println("含有负权回路")return}fmt.Println(distance[:n]) //return [0 6 3 8]
}func min(a int, b int) int {if a < b {return a}return b
}

相关内容

热门资讯

美国2年期国债收益率上涨15个... 原标题:美国2年期国债收益率上涨15个基点 美国2年期国债收益率上涨15个基...
汽车油箱结构是什么(汽车油箱结... 本篇文章极速百科给大家谈谈汽车油箱结构是什么,以及汽车油箱结构原理图解对应的知识点,希望对各位有所帮...
嵌入式 ADC使用手册完整版 ... 嵌入式 ADC使用手册完整版 (188977万字)💜&#...
重大消息战皇大厅开挂是真的吗... 您好:战皇大厅这款游戏可以开挂,确实是有挂的,需要了解加客服微信【8435338】很多玩家在这款游戏...
盘点十款牵手跑胡子为什么一直... 您好:牵手跑胡子这款游戏可以开挂,确实是有挂的,需要了解加客服微信【8435338】很多玩家在这款游...
senator香烟多少一盒(s... 今天给各位分享senator香烟多少一盒的知识,其中也会对sevebstars香烟进行解释,如果能碰...
终于懂了新荣耀斗牛真的有挂吗... 您好:新荣耀斗牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信8435338】很多玩家在这款游戏...
盘点十款明星麻将到底有没有挂... 您好:明星麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【5848499】很多玩家在这款游戏...
总结文章“新道游棋牌有透视挂吗... 您好:新道游棋牌这款游戏可以开挂,确实是有挂的,需要了解加客服微信【7682267】很多玩家在这款游...
终于懂了手机麻将到底有没有挂... 您好:手机麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【8435338】很多玩家在这款游戏...