Алгоритм "поднять-в-начало" — различия между версиями
Whiplash (обсуждение | вклад) м (→Операция разгрузки (discharged)) |
Whiplash (обсуждение | вклад) м (→Операция разгрузки (discharged)) |
||
Строка 16: | Строка 16: | ||
− | == Операция разгрузки ( | + | == Операция разгрузки (discharge) == |
'''Разгрузка (discharge)''' - операция, которая применяется к переполненной вершине <tex>u</tex>, для того чтобы протолкнуть поток через допустимые ребра в смежные вершины, при необходимости поднимая <tex>u</tex>, делая недопустимые ребра, выходящие из вершины <tex>u</tex>, допустимыми. | '''Разгрузка (discharge)''' - операция, которая применяется к переполненной вершине <tex>u</tex>, для того чтобы протолкнуть поток через допустимые ребра в смежные вершины, при необходимости поднимая <tex>u</tex>, делая недопустимые ребра, выходящие из вершины <tex>u</tex>, допустимыми. | ||
Строка 25: | Строка 25: | ||
Для каждой вершины <tex>u</tex> указатель <tex>current[u]</tex> - указатель на текущую вершину списка. Изначально <tex>current[u] = head[u]</tex>. | Для каждой вершины <tex>u</tex> указатель <tex>current[u]</tex> - указатель на текущую вершину списка. Изначально <tex>current[u] = head[u]</tex>. | ||
− | ''' | + | '''discharge'''(u) |
'''while''' e[u] > 0 | '''while''' e[u] > 0 | ||
v = current[u] | v = current[u] | ||
Строка 36: | Строка 36: | ||
'''else''' | '''else''' | ||
current[u] = next[v] | current[u] = next[v] | ||
+ | |||
+ | Докажем то, что когда операция '''discharge''' вызывает операции [[Метод проталкивания предпотока#Проталкивание (push)|push]] и [[Метод проталкивания предпотока#Подъем (relabel)|relable]], эти операции применимы. | ||
== Схема алгоритма == | == Схема алгоритма == |
Версия 22:49, 26 декабря 2012
Алгоритм "поднять-в-начало" (relabel-to-front) основан на методе проталкивание предпотока, но из-за тщательного выбора порядка выполнения операций проталкивания и подъема, время выполнения данного алгоритма составляет , что асимптотически не хуже, чем .
Содержание
Определения
сеть с истоком и стоком , - предпоток в , - функция высоты.
-Определение: |
Допустимое ребро (admissible edge) - ребро | , у которого и . В противном случае называется недопустимым (inadmissible).
Определение: |
Допустимая сеть (admissible network) - сеть | , где - множество допустимых ребер.
Идея
Операция разгрузки (discharge)
Разгрузка (discharge) - операция, которая применяется к переполненной вершине
, для того чтобы протолкнуть поток через допустимые ребра в смежные вершины, при необходимости поднимая , делая недопустимые ребра, выходящие из вершины , допустимыми.Будем хранить для каждой вершины
список (список вершин смежных с ней). То есть список содержит каждую вершину такую, что в сети или .На первую вершину в списке указывает указатель
. Для перехода к следующей вершине в списке за , поддерживается указатель . Он равен если - последняя вершина в списке.Для каждой вершины
указатель - указатель на текущую вершину списка. Изначально .discharge(u) while e[u] > 0 v = current[u] if v = null relabel(u) current[u] = head[N[u]] else if c(u, v) > 0 and h[u] = h[v] + 1 push(u, v) else current[u] = next[v]
Докажем то, что когда операция discharge вызывает операции push и relable, эти операции применимы.
Схема алгоритма
Анализ
Источники
- Кормен Т., Лейзерсон Ч., Ривест Р. Алгоритмы: построение и анализ. — 2-е изд. — М.: Издательский дом «Вильямс», 2011. — С. 774—785.
- Алгоритм проталкивания предпотока — Википедия