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