Алгоритм Куна для поиска максимального паросочетания — различия между версиями
(→Литература) |
|||
Строка 2: | Строка 2: | ||
|statement= | |statement= | ||
Если из вершины х не существует дополняющей цепи относительно паросочетания М, то если паросочетание М' получается из М изменением вдоль дополняющей цепи, то из х не существует дополняющей цепи в М'. | Если из вершины х не существует дополняющей цепи относительно паросочетания М, то если паросочетание М' получается из М изменением вдоль дополняющей цепи, то из х не существует дополняющей цепи в М'. | ||
− | |proof=Доказательство от противного! | + | |proof=Доказательство от противного! Рассмотрим изменения, которые мы внесли в М вдоль дополняющей цепи, чтобы получить паросочетание М'. В этой цепи все промежуточные вершины были насыщенными, а концы свободные. После изменения вдоль этой цепи все вершины, лежащие на этой цепи станут насыщенными. Допустим, что из х появилась дополняющая цепь относительно M'. Тогда появившаяся дополняющая цепь должна проходить хотя бы через одну из концевых вершин в той дополняющей цепи, относительно которой вносили изменения, поскольку иначе такая же дополняющая цепь была и в паросочетании М. Однако поскольку в паросочетании М концевые вершины не насыщены, то из вершины х в паросочетании М есть все равно есть дополняющая цепь. Надо рассмотреть часть дополняющей цепи в М', ограниченную концом текущей дополняющей цепи и концом той дополняющей цепи, вдоль которой вносили изменения, такую что вершина х будет промежуточной. Легко заметить что в такой цепи все промежуточные вершины насыщенные, а концы свободны, поэтому она является дополняющей. Значит, мы пришли к противоречию, поскольку в паросочетании М нет дополняющих цепей из вершины х. |
}} | }} | ||
==Алгоритм== | ==Алгоритм== |
Версия 21:48, 14 декабря 2010
Теорема: |
Если из вершины х не существует дополняющей цепи относительно паросочетания М, то если паросочетание М' получается из М изменением вдоль дополняющей цепи, то из х не существует дополняющей цепи в М'. |
Доказательство: |
Доказательство от противного! Рассмотрим изменения, которые мы внесли в М вдоль дополняющей цепи, чтобы получить паросочетание М'. В этой цепи все промежуточные вершины были насыщенными, а концы свободные. После изменения вдоль этой цепи все вершины, лежащие на этой цепи станут насыщенными. Допустим, что из х появилась дополняющая цепь относительно M'. Тогда появившаяся дополняющая цепь должна проходить хотя бы через одну из концевых вершин в той дополняющей цепи, относительно которой вносили изменения, поскольку иначе такая же дополняющая цепь была и в паросочетании М. Однако поскольку в паросочетании М концевые вершины не насыщены, то из вершины х в паросочетании М есть все равно есть дополняющая цепь. Надо рассмотреть часть дополняющей цепи в М', ограниченную концом текущей дополняющей цепи и концом той дополняющей цепи, вдоль которой вносили изменения, такую что вершина х будет промежуточной. Легко заметить что в такой цепи все промежуточные вершины насыщенные, а концы свободны, поэтому она является дополняющей. Значит, мы пришли к противоречию, поскольку в паросочетании М нет дополняющих цепей из вершины х. |
Содержание
Алгоритм
Пусть дан двудольный граф
1) Просматриваем вершины из доли .
2) Будем искать дополняющую цепь из
поиском в глубину.3) Если цепь найдена, инвертируем все ребра на этой цепи.
В любой момент времени текущим паросочетанием будет множество ребер, направленных из теоремы Бержа и доказанной выше теоремы.
в . Корректность работы алгоритма следует изПсевдокод
bool dfs(x): vis[x] = true for: k = py[y] if (k == -1) or ((not vis[k]) and (dfs(k))): py[y] = x return true return false Kuhn(): py[] = -1 for : vis[] = false dfs(s)
Время работы
Итак, алгоритм Куна можно представить как серию из |
| запусков обхода в глубину на всём графе. Следовательно, всего этот алгоритм исполняется за время , что в худшем случае есть .Источники
Асанов М., Баранский В., Расин В. - Дискретная математика: Графы, матроиды, алгоритмы — Ижевск: ННЦ "Регулярная и хаотическая динамика", 2001, 291 стр.