這篇文章將為大家詳細講解有關(guān)python中Bellman-Ford算法有什么用,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)作為成都網(wǎng)站建設(shè)公司,專注網(wǎng)站建設(shè)、網(wǎng)站設(shè)計,有關(guān)企業(yè)網(wǎng)站設(shè)計方案、改版、費用等問題,行業(yè)涉及成都會所設(shè)計等多個領(lǐng)域,已為上千家企業(yè)服務(wù),得到了客戶的尊重與認可。
說明
1、Bellman-Ford算法是包含負權(quán)圖的單源最短路徑算法。
算法原理是對圖進行V-1放松操作,獲得所有可能的最短路徑。
2、Bellman-Ford算法可以處理負面邊緣。它的基本操作擴展是在深度上搜索,而放松操作是在廣度上搜索。
它可以在不影響結(jié)果的情況下操作負面邊緣。
Bellman-Ford算法效率低,時間復雜度高達o(V*E),v、e分別為頂點和邊數(shù)。SPFA是Bellman-Ford的隊列優(yōu)化,通過維護隊列可以大幅度減少重復計算,時間復雜度為o(k*E)。
實例
def bellman_ford( graph, source ): distance = {} parent = {} for node in graph: distance[node] = float( 'Inf' ) parent[node] = None distance[source] = 0 for i in range( len( graph ) - 1 ): for from_node in graph: for to_node in graph[from_node]: if distance[to_node] > graph[from_node][to_node] + distance[from_node]: distance[to_node] = graph[from_node][to_node] + distance[from_node] parent[to_node] = from_node for from_node in graph: for to_node in graph[from_node]: if distance[to_node] > distance[from_node] + graph[from_node][to_node]: return None, None return distance, parent def test(): graph = { 'a': {'b': -1, 'c': 4}, 'b': {'c': 3, 'd': 2, 'e': 2}, 'c': {}, 'd': {'b': 1, 'c': 5}, 'e': {'d': -3} } distance, parent = bellman_ford( graph, 'a' ) print distance print parent if __name__ == '__main__': test()
關(guān)于“python中Bellman-Ford算法有什么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
本文標題:python中Bellman-Ford算法有什么用
標題路徑:http://www.rwnh.cn/article4/peojie.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、做網(wǎng)站、虛擬主機、、服務(wù)器托管、微信公眾號
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)