Алгоритм Эдмондса - Edmonds algorithm

В теория графов, Алгоритм Эдмондса или же Алгоритм Чу – Лю / Эдмондса является алгоритм для поиска охватывающий древообразование минимального веса (иногда называемый оптимальное ветвление).Это направленный аналог минимальное остовное дерево Алгоритм был независимо предложен сначала Йоенг-Джин Чу и Ценг-Хонг Лю (1965), а затем Джек Эдмондс (1967).

Алгоритм

Описание

Алгоритм принимает на вход ориентированный граф куда это набор узлов и - множество направленных ребер, выделенная вершина называется корень, и действительный вес для каждого края . Он возвращает охват древообразование укорененный в минимального веса, где вес древесного ствола определяется как сумма веса его краев, .

Алгоритм имеет рекурсивное описание. обозначают функцию, которая возвращает остовное древообразование с корнем минимального веса.Сначала удаляем края с чей пункт назначения Мы также можем заменить любой набор параллельных ребер (ребра между одной парой вершин в одном направлении) одним ребром с весом, равным минимальному весу этих параллельных ребер.

Теперь для каждого узла кроме корня, найдите ребро, входящее в наименьшего веса (с произвольным разрывом связей) .Обозначим источник этого ребра .Если набор ребер не содержит циклов, то .

Иначе, содержит хотя бы один цикл. Произвольно выберите один из этих циклов и назовите его .Теперь мы определяем новый взвешенный ориентированный граф в котором цикл "сворачивается" в один узел следующим образом:

Узлы узлы не в плюс новый узел обозначен .

  • Если это край в с и (край, входящий в цикл), затем включите в новый край , и определим .
  • Если это край в с и (край, уходящий от цикла), затем включите новый край , и определим .
  • Если это край в с и (ребро, не связанное с циклом), затем включить в новый край , и определим .

Для каждого края в , мы помним, какое ребро в это соответствует.

Теперь найдите минимальный охват древовидности из используя звонок остовное древообразование, каждая вершина имеет ровно одно входящее ребро. быть уникальным входящим краем для в Это ребро соответствует ребру с .Удалите край из , прерывая цикл. Отметьте каждое оставшееся ребро в .Для каждого края в отметьте соответствующий край в .Теперь определим быть набором отмеченных краев, которые образуют минимальное остовное древообразование.

Заметьте, что определяется в терминах , с имеющий строго меньше вершин, чем . обнаружение для одновершинного графа тривиально (это просто сам), поэтому рекурсивный алгоритм гарантированно завершится.

Продолжительность

Время работы этого алгоритма . Более быстрая реализация алгоритма за счет Роберт Тарджан бежит во времени за разреженные графики и для плотных графов. Это так быстро, как Алгоритм Прима для неориентированного минимального остовного дерева. В 1986 году Габоу, Галил, Спенсер, Комптон и Тарджан разработали более быструю реализацию со временем выполнения. .

Рекомендации

  • Чу, Ю. Дж .; Лю Т. Х. (1965), "О кратчайшем древовидности ориентированного графа", Наука Синица, 14: 1396–1400
  • Эдмондс, Дж. (1967), "Оптимальные ветвления", Журнал исследований Национального бюро стандартов Раздел B, 71B (4): 233–240, Дои:10.6028 / jres.071b.032
  • Тарьян, Р.Э. (1977), "Поиск оптимальных ветвлений", Сети, 7: 25–35, Дои:10.1002 / нетто.3230070103
  • Camerini, P.M .; Fratta, L .; Maffioli, F. (1979), "Заметка о поиске оптимальных ветвлений", Сети, 9 (4): 309–312, Дои:10.1002 / нетто.3230090403
  • Гиббонс, Алан (1985), Алгоритмическая теория графов, Издательство Кембриджского университета, ISBN  0-521-28881-9
  • Gabow, H.N .; Галил, З .; Спенсер, Т .; Тарьян, Р.Э. (1986), «Эффективные алгоритмы поиска минимальных остовных деревьев в неориентированных и ориентированных графах», Комбинаторика, 6 (2): 109–122, Дои:10.1007 / bf02579168

внешняя ссылка