Алгоритм Форда-Фалкерсона для поиска максимального паросочетания — различия между версиями
(Новая страница: «{{В разработке}} ==Алгоритм== Пусть дан двудольный граф <tex>G(V, E)</tex> и требуется найти максима…») |
(→Псевдокод) |
||
| Строка 26: | Строка 26: | ||
'''for''' <tex>xy \in E</tex> | '''for''' <tex>xy \in E</tex> | ||
'''if''' py[y] = -1 | '''if''' py[y] = -1 | ||
| − | py[y] = x | + | py[y] = x |
| + | px[x] = y | ||
return true | return true | ||
| − | '''else''' if dfs( | + | '''else''' if dfs(py4w[y]) |
| − | + | py[y] = x | |
| + | px[x] = y | ||
return true | return true | ||
return false | return false | ||
| + | px[] = -1 | ||
| + | py[] = -1 | ||
'''while''' (changed) | '''while''' (changed) | ||
changed = false | changed = false | ||
Версия 23:54, 13 декабря 2010
Эта статья находится в разработке!
Алгоритм
Пусть дан двудольный граф и требуется найти максимальное паросочетание в нём. Преобразуем его в граф следующим образом
Обазначим доли исходного графа как и . Тогда
1) Будем искать путь из в поиском в глубину.
2) Если путь найден, инвертируем все ребра на пути.
3) Если путь не был найден, значит текущее паросочетание является максимальным и алгоритм завершает работу. Иначе переходим к пункту 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(py4w[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