Алгоритм Куна для поиска максимального паросочетания
Версия от 21:57, 14 декабря 2010; 192.168.0.2 (обсуждение)
Теорема: |
Если из вершины не существует дополняющей цепи относительно паросочетания , то если паросочетание получается из изменением вдоль дополняющей цепи, то из не существует дополняющей цепи в . |
Доказательство: |
Доказательство от противного! Рассмотрим изменения, которые мы внесли в | вдоль дополняющей цепи, чтобы получить паросочетание М'. В этой цепи все промежуточные вершины были насыщенными, а концы свободные. После изменения вдоль этой цепи все вершины, лежащие на этой цепи станут насыщенными. Допустим, что из появилась дополняющая цепь относительно 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 стр.