是否有一种有效的算法来打印流网络中所有边缘不相交的路径?

Is there an efficient algorithm for printing all edge-disjoint paths in a flow network?

我很好奇是否有一种有效的算法可以实际返回流程图中从 s 到 t 的所有边不相交的路径?

例如,采用以下网络,其中每条边的容量为 1:

显然只有两条边不相交的路径:

  1. s -> A -> B -> t
  2. s -> C -> D -> E -> F -> t

我猜您需要使用 Ford-Fulkerson 算法的修改版本来跟踪增强路径。但是它如何覆盖以前的错误路径(例如我的示例中的 s -> A -> E -> F -> t)。

正如您所注意到的,Ford--Fulkerson 使用的增广路径并不是立即有用的。

您可以做的是 运行 F--F(或任何最大流算法)完成,然后贪婪地从结果流中提取路径。要提取路径,请从 s 开始。如果没有剩余的传出流弧,则没有剩余的路径可以提取。否则,选择尾部为当前顶点的任何流弧,移动到该弧的头部,删除该弧,重复直到当前顶点为 t,打印弧序列。

如果您需要简单的路径,那么您还需要检测路径何时折回自身并删除循环。这可以通过将当前访问的顶点映射到路径中它们的传入弧的索引来有效地完成。

如果需要较短的简单路径,可以将 F--F 换成最小成本流算法并省略循环检测(具有正成本循环的流不能是最小成本)。