Алгоритм Форда-Фалкерсона для поиска максимального паросочетания — различия между версиями
(→Идея алгоритма) |
м (→Корректность алгоритма) |
||
Строка 14: | Строка 14: | ||
# Путь из <tex>s</tex> в <tex>t</tex> является [[Теорема о максимальном паросочетании и дополняющих цепях|дополняющей цепью]] для исходного графа <tex>G</tex>. Действительно, в этом пути два конца свободны, т.к. они не являются ребрами графа <tex>G</tex> и, значит, не входят в паросочетание. По построению графа <tex>G'</tex> этот путь содержит нечетное число ребер (т.к. в <tex>G'</tex> нет ребер из <tex>s</tex> в <tex>y \in R</tex>, а так же ребер из <tex>x \in L</tex> в <tex>t</tex>, то попасть из истока в сток можно только через какие-либо две вершины <tex>x \in L</tex> и <tex>y \in R</tex>, расстояние между которыми в двудольном графе (в ребрах) - нечетная величина). В таком случае ребра пути <tex>s-t</tex> можно пронумеровать так, чтобы нечетные ребра были свободными, а четные - покрытыми. | # Путь из <tex>s</tex> в <tex>t</tex> является [[Теорема о максимальном паросочетании и дополняющих цепях|дополняющей цепью]] для исходного графа <tex>G</tex>. Действительно, в этом пути два конца свободны, т.к. они не являются ребрами графа <tex>G</tex> и, значит, не входят в паросочетание. По построению графа <tex>G'</tex> этот путь содержит нечетное число ребер (т.к. в <tex>G'</tex> нет ребер из <tex>s</tex> в <tex>y \in R</tex>, а так же ребер из <tex>x \in L</tex> в <tex>t</tex>, то попасть из истока в сток можно только через какие-либо две вершины <tex>x \in L</tex> и <tex>y \in R</tex>, расстояние между которыми в двудольном графе (в ребрах) - нечетная величина). В таком случае ребра пути <tex>s-t</tex> можно пронумеровать так, чтобы нечетные ребра были свободными, а четные - покрытыми. | ||
− | # | + | # Инвертирование ребер не меняет пути, следовательно, он остается дополняющей цепью. |
# В найденном пути вершины не повторяются (это свойство поиска в глубину), тогда множество ребер, ведущих только из <tex>R</tex> в <tex>L</tex> является паросочетанием. | # В найденном пути вершины не повторяются (это свойство поиска в глубину), тогда множество ребер, ведущих только из <tex>R</tex> в <tex>L</tex> является паросочетанием. | ||
# Путь не был найден. Это значит, что не существует дополняющей цепи для графа <tex>G'</tex>. Тогда по [[Теорема о максимальном паросочетании и дополняющих цепях|теореме]] текущее паросочетание является максимальным. | # Путь не был найден. Это значит, что не существует дополняющей цепи для графа <tex>G'</tex>. Тогда по [[Теорема о максимальном паросочетании и дополняющих цепях|теореме]] текущее паросочетание является максимальным. |
Версия 21:33, 29 декабря 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
is_path = true;
while (is_path)
is_path = false
vis[] = false
for
if (px[x] == -1)
if dfs(x)
is_path = true