Поиск максимального потока в транспортной сети
Содержание
1 Постановка задачи
Транспортной сетью называется ориентированный граф G = (V, E), каждому ребру e \in E которого приписана неотрицательная пропускная способность c(e) \ge 0. Будем считать, что вместе с каждым ребром e = (v, w) \in E граф содержит и обратное к нему e^R = (w, v) (при необходимости приписывая ему нулевую пропускную способность).
Пусть в графе G выделены две вершины: источник s и сток t. Без ограничения общности можно считать, что все остальные вершины лежат на каком-либо пути из s в t. Потоком называется функция f: E \to \mathbb{R}, удовлетворяющая следующим требованиям:
- ограничение по пропускной способности: f(e) \le c(e);
- антисимметричность: f(e^R) = -f(e);
- закон сохранения потока:
- \forall v \ne s, t: \quad \sum_{e = (w, v)} f(e) = \sum_{e = (v, w)} f(e).
Величиной потока называется суммарный поток из источника:
- \left \vert f \right \vert = \sum_{e = (s, v)} f(e).
Задача о максимальном потоке в транспортной сети. Требуется найти поток максимальной величины:
- \left \vert f \right \vert \to \max.
2 Свойства задачи
Суммарный поток из источника равен суммарному потоку в сток:
- \forall v \ne s, t: \quad \sum_{e = (s, v)} f(e) = \sum_{e = (v, t)} f(e).
(Для доказательства достаточно просуммировать закон сохранения потока для всех вершин, кроме источника и стока.)
3 Варианты задачи
В зависимости от ограничений на значения пропускной способности:
- произвольная положительная пропускная способность;
- целая пропускная способность;
- единичная пропускная способность (в этом случае максимальный поток равен рёберной связности графа).
4 Алгоритмы решения задачи
- Алгоритм Форда-Фалкерсона[1] и его варианты[2][3] со сложностью O(n^2m) (для алгоритма Диница). В случае целых пропускных способностей, не превосходящих K, сложность O(Km).
- Алгоритм проталкивания предпотока[4] со сложностью O(mn \ln n) (при использовании динамических деревьев Тарьяна-Слитора[5][6]).
Обозначения: m – число рёбер, n – число вершин.
5 Ссылки
- ↑ Ford, L R, Jr., and D R Fulkerson. “Maximal Flow Through a Network.” Canadian Journal of Mathematics 8 (1956): 399–404. doi:10.4153/CJM-1956-045-5.
- ↑ Edmonds, Jack, and Richard M Karp. “Theoretical Improvements in Algorithmic Efficiency for Network Flow Problems.” Journal of the ACM 19, no. 2 (April 1972): 248–64. doi:10.1145/321694.321699.
- ↑ Диниц, Е. А. “Алгоритм решения задачи о максимальном потоке в сети со степенной оценкой.” Доклады АН СССР 194, no. 4 (1970): 754–57.
- ↑ Goldberg, Andrew V, and Robert Endre Tarjan. “A New Approach to the Maximum-Flow Problem.” Journal of the ACM 35, no. 4 (October 1988): 921–40. doi:10.1145/48014.61051.
- ↑ Sleator, Daniel D, and Robert Endre Tarjan. “A Data Structure for Dynamic Trees,” STOC'81, 114–22, New York, USA: ACM Press, 1981. doi:10.1145/800076.802464.
- ↑ Sleator, Daniel Dominic, and Robert Endre Tarjan. “Self-Adjusting Binary Search Trees.” Journal of the ACM 32, no. 3 (July 1985): 652–86. doi:10.1145/3828.3835.