Алгоритм масштабирования потока — различия между версиями
(→Алгоритм) |
(→Оценка времени работы) |
||
| Строка 32: | Строка 32: | ||
[[Файл: scaling.jpg|250px|thumb|Разрез <tex> C_k </tex>]] | [[Файл: scaling.jpg|250px|thumb|Разрез <tex> C_k </tex>]] | ||
| − | В конце итерации с масштабом <tex> \Delta = 2^k </tex>, сеть <tex> G_{f_k} </tex> может быть разбита на два непересекающихся множества <tex> A_k </tex> и <tex> \overline{A_k} </tex>. То есть образуется [[Разрез,_лемма_о_потоке_через_разрез|разрез]] <tex> C_k = \langle A_k, \overline{A_k} \rangle </tex>. | + | В конце итерации с масштабом <tex> \Delta = 2^k </tex>, сеть <tex> G_{f_k} </tex> может быть разбита на два непересекающихся множества <tex> A_k </tex> и <tex> \overline{A_k} </tex> так, что остаточная пропускная способность каждого ребра, идущего из <tex> A_k </tex> в <tex> \overline{A_k} </tex>, не превосходит масштаба <tex> \Delta </tex>. То есть образуется [[Разрез,_лемма_о_потоке_через_разрез|разрез]] <tex> C_k = \langle A_k, \overline{A_k} \rangle </tex>. |
| − | При этом | + | При этом, количество таких ребер не превосходит <tex> E </tex>. |
Значит, значение остаточного потока не может превосходить <tex> \Delta E = 2^k E </tex>. | Значит, значение остаточного потока не может превосходить <tex> \Delta E = 2^k E </tex>. | ||
}} | }} | ||
Версия 19:41, 2 марта 2012
Содержание
Алгоритм
Алгоритм масштабирования потока — алгоритм поиска максимального потока, основывающийся на предположении, что пропускные способности всех ребер выражаются целыми числами. Время работы алгоритма составляет , что может быть много меньше времени работы аналогичных алгоритмов поиска максимального потока.
Пусть дана сеть , все ребра которой имеют целочисленную пропускную способность. Обозначим за максимальную пропускную способность: .
Идея алгоритма заключается в нахождении путей с высокой пропускной способностью в первую очередь, чтобы сразу сильно увеличивать поток по ним, а затем по всем остальным. Для этого воспользуемся масштабом . Изначально положим .
На каждой итерации в дополняющей сети находим дополняющие пути с пропускной способностью не меньшей , увеличиваем поток вдоль них. Уменьшив масштаб в раза, переходим к следующей итерации.
Заметим, что при алгоритм вырождается в алгоритм Эдмондса-Карпа, вследствие чего является корректным.
Количество необходимых увеличений путей, основанных на кратчайших путях, может быть много больше количества увеличений, основанных на путях с высокой пропускной способностью.
Оценка времени работы
| Утверждение: | ||||||||||||||||||
Время работы алгоритма — . | ||||||||||||||||||
|
В ходе выполнения алгоритма масштаб принимает следующие значения: . Тогда — количество итераций алгоритма.
| ||||||||||||||||||
Псевдокод
Max_Flow_By_Scaling(G,s,t)
while
do while в существует увеличивающий путь с пропускной способностью не меньшей
do
увеличить поток по рёбрам на
обновить
return