Алгоритм масштабирования потока — различия между версиями
(→Алгоритм) |
(→Алгоритм) |
||
| Строка 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> раза, переходим к следующей итерации. | Уменьшив уровень <tex> \Delta </tex> в <tex> 2 </tex> раза, переходим к следующей итерации. | ||
| − | Количество необходимых | + | Количество необходимых дополнений путей, основанных на кратчайших путях, может быть много больше количества дополнений, основанных на путях с высокой пропускной способностью. |
{|border="0" cellpadding="5" width=30% align=center | {|border="0" cellpadding="5" width=30% align=center | ||
| − | |[[Файл: augmentations1.png|250px|thumb|center|Выбор | + | |[[Файл: augmentations1.png|250px|thumb|center|Выбор дополняющих путей в порядке длины]] |
|[[Файл: augmentations2.png|250px|thumb|center|Выбор пути с высокой пропускной способностью в первую очередь]] | |[[Файл: augmentations2.png|250px|thumb|center|Выбор пути с высокой пропускной способностью в первую очередь]] | ||
|} | |} | ||
Версия 01:24, 29 февраля 2012
Алгоритм
Пусть дана сеть , все ребра которой имеют целочисленную пропускную способность. Обозначим за максимальную пропускную способность: .
Идея алгоритма заключается в нахождении путей с высокой пропускной способностью в первую очередь, чтобы сразу сильно увеличивать поток по ним, а затем по всем остальным. Для этого воспользуемся параметром . Изначально положим .
На каждой итерации в дополняющей сети находим дополняющие пути с пропускной способностью не меньшей , увеличиваем поток вдоль них. Уменьшив уровень в раза, переходим к следующей итерации.
Количество необходимых дополнений путей, основанных на кратчайших путях, может быть много больше количества дополнений, основанных на путях с высокой пропускной способностью.
Корректность алгоритма
Заметим, что при алгоритм вырождается в алгоритм Эдмондса-Карпа, вследствие чего является корректным.
Оценка времени работы
| Утверждение: | ||||||||||||||
Время работы алгоритма — . | ||||||||||||||
|
Пусть — множество уровней.
| ||||||||||||||
Псевдокод
Max_Flow_By_Scaling(G,s,t)
while
do while в существует увеличивающий путь с пропускной способностью не меньшей
do
увеличить поток по рёбрам на
обновить
return