Алгоритм Форда-Фалкерсона для поиска максимального паросочетания
Версия от 20:34, 10 декабря 2010; Байдаров Андрей (обсуждение | вклад) (Новая страница: «{{В разработке}} ==Алгоритм== Пусть дан двудольный граф <tex>G(V, E)</tex> и требуется найти максима…»)
Эта статья находится в разработке!
Алгоритм
Пусть дан двудольный граф
и требуется найти максимальное паросочетание в нём. Преобразуем его в граф следующим образом
Обазначим доли исходного графа как
и . Тогда1) Будем искать путь из
в поиском в глубину.2) Если путь найден, инвертируем все ребра на пути.
3) Если путь не был найден, значит текущее паросочетание является максимальным и алгоритм завершает работу. Иначе переходим к пункту 1)
В любой момент времени текущим паросочетанием будет множество ребер, направленных из
в .
Очевидно, что путь из в является дополняющей цепью. Тогда корректность алгоритма следует из теоремы Бержа.
Псевдокод
bool dfs(x)
if vis[x]
return false
vis[x] = true
for
if py[y] = -1
py[y] = x
return true
else if dfs(p[y])
p[y] = x
return true
return false
while (changed)
changed = false
vis[] = false
for для каждой
if (px[x] == -1)
if dfs(x)
changed = true