Критерий Тарьяна минимальности остовного дерева
Теорема (критерий Тарьяна минимальности остовного дерева): |
Остовное дерево минимально тогда и только тогда, когда любое ребро не из дерева является максимальным на цикле, который образуется при его добавлении в дерево. |
Доказательство: |
Легко заметить, что остовное дерево, не удовлетворяющее условию, не минимально: Если существует ребро, не максимальное на образовавшемся цикле, мы можем уменьшить вес дерева, добавив это ребро и удалив максимальное. Теперь докажем, что дерево , удовлетворяющее условию, минимально:Для этого покажем, что для любого разреза исходного графа , вес ребра , пересекающего этот разрез, минимален среди всех ребер , пересекающих этот разрез. Действительно, рассмотрим ребро , пересекающее и путь между вершинами и по дереву .По условию теоремы, вес Найдем теперь минимальное остовное дерево графа используя не меньше веса любого ребра на этом пути. При этом пересекает , поэтому на этом пути найдется ребро, пересекающее этот разрез. Но единственное такое ребро в остовном дереве - это . Таким образом, , ч. т. д. алгоритм Краскала, который представляет собой применение леммы о безопасном ребре некоторое число раз. На каждом шаге к строящемуся остову будет добавляться ребро минимального веса, пересекающего некоторый разрез, а этот вес, как было показано выше, равен весу ребра , пересекающего этот разрез. Поэтому вес получившегося минимального остова будет равен весу , что и требовалось. |
Литература
- Кормен Т., Лейзерсон Ч., Ривест Р., Штайн К. — Алгоритмы. Построение и анализ.