Алгоритм Форда-Фалкерсона для поиска максимального паросочетания — различия между версиями
(→Алгоритм) |
|||
Строка 8: | Строка 8: | ||
# Будем искать путь из <tex>s</tex> в <tex>t</tex> поиском в глубину. | # Будем искать путь из <tex>s</tex> в <tex>t</tex> поиском в глубину. | ||
# Если путь найден, инвертируем все ребра на пути. | # Если путь найден, инвертируем все ребра на пути. | ||
− | # Если путь не был найден, значит текущее паросочетание является максимальным и алгоритм завершает работу. Иначе переходим к пункту 1. | + | # Если путь не был найден, значит текущее паросочетание является максимальным, и алгоритм завершает работу. Иначе переходим к пункту 1. |
В любой момент времени текущим паросочетанием будет множество ребер, направленных из <tex>R</tex> в <tex>L</tex>. | В любой момент времени текущим паросочетанием будет множество ребер, направленных из <tex>R</tex> в <tex>L</tex>. |
Версия 05:14, 14 октября 2011
Алгоритм
Пусть дан двудольный граф максимальное паросочетание в нём. Преобразуем его в граф следующим образом:
и требуется найти
Обозначим доли исходного графа как
и . Тогда- Будем искать путь из в поиском в глубину.
- Если путь найден, инвертируем все ребра на пути.
- Если путь не был найден, значит текущее паросочетание является максимальным, и алгоритм завершает работу. Иначе переходим к пункту 1.
В любой момент времени текущим паросочетанием будет множество ребер, направленных из
в .
Очевидно, что путь из в является дополняющей цепью для исходного графа . Тогда корректность алгоритма следует из теоремы Бержа.
Псевдокод
bool dfs(x)
if vis[x]
return false
vis[x] = true
for
if py[y] = -1
py[y] = x
px[x] = y
return true
else if dfs(py[y])
py[y] = x
px[x] = y
return true
return false
px[] = -1
py[] = -1
while (changed)
changed = false
vis[] = false
for
if (px[x] == -1)
if dfs(x)
changed = true
Литература
- Кормен, Томас Х., Лейзерсон, Чарльз И., Ривест, Рональд Л., Штайн Клиффорд Алгоритмы: построение и анализ, 2-е издание. Пер. с англ. — М.:Издательский дом "Вильямс", 2010. — 1296 с.: ил. — Парал. тит. англ. — ISBN 978-5-8459-0857-5 (рус.)