Ford-Fulkerson算法概念详解 Python实现Ford-Fulkerson算法

发布:2022-11-03 17:31:33
阅读:27463
作者:网络整理
分享:复制链接

Ford-Fulkerson算法是贪心算法,用于计算网络中的最大流量。其原理是找到剩余容量为正的增广路径,只要找到增广路径,就可以继续增加路径和计算流量。直到增广路径不再存在,这时就能得出最大流量。

Ford-Fulkerson算法的术语

剩余容量:就是将容量减去流量,在Ford-Fulkerson算法中剩余容量是正数,才能继续作为路径。

残差网络:是一个具有相同顶点和边的网络,使用残差容量作为容量。

增广路径:是残差图中从源点到接收点的路径,最终容量为0。

Ford-Fulkerson算法原理示例

可能概念不是很清晰,下面来看一个示例,流网络所有边的初始流量均为0,并有对应的容量上限,设起始点为S,接收点为T。

路径一,S-A-B-T路径剩余容量为8、9、2,最小值为2,因此路径一的流量为2,这时网络图的流量为2。

路径二,S-D-C-T路径剩余容量为3、4、5,最小值为3,因此我们可以将流量增加3,这时网络的流量为5。

路径三,S-A-B-D-C-T路径剩余容量为6、7、7、1、2,最小值为1,因此流量增加1,这时网络的流量为6。

至此,已经没有为正数的剩余容量,得出该流网络的最大流是6。

Python实现Ford-Fulkerson算法

from collections import defaultdict

class Graph:

def __init__(self, graph):
self.graph = graph
self. ROW = len(graph)

def searching_algo_BFS(self, s, t, parent):

visited = [False] * (self.ROW)
queue = []

queue.append(s)
visited[s] = True

while queue:

u = queue.pop(0)

for ind, val in enumerate(self.graph[u]):
if visited[ind] == False and val > 0:
queue.append(ind)
visited[ind] = True
parent[ind] = u

return True if visited[t] else False

def ford_fulkerson(self, source, sink):
parent = [-1] * (self.ROW)
max_flow = 0

while self.searching_algo_BFS(source, sink, parent):

path_flow = float("Inf")
s = sink
while(s != source):
path_flow = min(path_flow, self.graph[parent[s]][s])
s = parent[s]

max_flow += path_flow

v = sink
while(v != source):
u = parent[v]
self.graph[u][v] -= path_flow
self.graph[v][u] += path_flow
v = parent[v]

return max_flow

graph = [[0, 8, 0, 0, 3, 0],
[0, 0, 9, 0, 0, 0],
[0, 0, 0, 0, 7, 2],
[0, 0, 0, 0, 0, 5],
[0, 0, 7, 4, 0, 0],
[0, 0, 0, 0, 0, 0]]

g = Graph(graph)

source = 0
sink = 5

print("Max Flow: %d " % g.ford_fulkerson(source, sink))
最新文章
网易灵动荣登2025中国技术力量年度榜单 ,装载机器人入选年度具身智能明星产品
2025-12-31 15:22:38
AI时代,为什么90%的协作都死在了“说不清楚”上?|有灵智能体有奖邀测
2025-12-30 11:05:29
行动中的认知:预测加工框架下的具身智能——未来展望:迈向自主行动的通用智能
2025-12-29 15:45:13
行动中的认知:预测加工框架下的具身智能——实现路径:主动推断与具身性的融合
2025-12-29 15:44:06
行动中的认知:预测加工框架下的具身智能——理论交融:从“具身心智”到“预测心智”
2025-12-29 15:42:49
热门文章
1《中国日报》全英文报道网易有灵平台,解读人机协作就业新机遇
2真实故事分享|从全职宝妈到备考学生,他们用“碎片时间”灵活兼职、月入千元
3CNCC2023网易伏羲承办分论坛圆满落幕,CCF-网易雷火联合基金指南正式发布!
4网易伏羲发布网易有灵机器人测试版,人机协作助推产业智能升级
5网易伏羲受邀亮相2024云栖大会,共绘云上AI新篇章
6什么是“具身智能”? 和人形机器人有什么关系?
7世界互联网大会发布2023互联网创新发展十大案例,网易无人装载机器人入选
8无人装载机器人、AI美术平台首次亮相,网易伏羲将为10万人提供人机协作就业机会
9云启未来,智绘中国,网易伏羲亮相《云上的中国3:剧变中的AI时代》
10逆水寒携手网易伏羲邀请五大AI厂商,共创全球首个游戏内AI竞技场
扫码进群
微信群
了解更多资讯