Алгоритм масштабирования потока — различия между версиями
(→Алгоритм) |
(→Алгоритм) |
||
Строка 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