Алгоритм масштабирования потока — различия между версиями
(→Оценка времени работы) |
(→Оценка времени работы) |
||
| Строка 41: | Строка 41: | ||
Общее количество увеличивающих путей не превышает <tex> O(E \log U) </tex>. | Общее количество увеличивающих путей не превышает <tex> O(E \log U) </tex>. | ||
|proof= | |proof= | ||
| − | Следует из предыдущей леммы и факта, что количество уровней {{---}} <tex> O(\ | + | Следует из предыдущей леммы и факта, что количество уровней {{---}} <tex> O(\log U) </tex>. |
}} | }} | ||
Версия 01:02, 29 февраля 2012
Алгоритм
Пусть дана сеть , все ребра которой имеют целочисленную пропускную способность. Обозначим за максимальную пропускную способность: .
Идея алгоритма заключается в нахождении путей с высокой пропускной способностью в первую очередь, чтобы сразу сильно увеличивать поток по ним, а затем по всем остальным. Для этого воспользуемся уровнем . Изначально положим .
На каждой итерации в дополняющей сети находим увеличивающие пути с пропускной способностью, не меньшей , и увеличим поток вдоль них. Уменьшив уровень в раза, переходим к следующей итерации.
Корректность алгоритма
Заметим, что при алгоритм вырождается в алгоритм Эдмондса-Карпа, вследствие чего является корректным.
Оценка времени работы
| Утверждение: | ||||||||||||||
Время работы алгоритма — . | ||||||||||||||
|
Пусть — множество уровней.
| ||||||||||||||
Псевдокод
Max_Flow_By_Scaling(G,s,t)
while
do while в существует увеличивающий путь с пропускной способностью не меньшей
do
увеличить поток по рёбрам на
обновить
return