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