Максимальное количество попарно непересекающихся остовных деревьев в графе с n вершинами — различия между версиями
(→Попарно непересекающиеся остовные деревья) |
(→Описание алгоритма) |
||
Строка 10: | Строка 10: | ||
==Построение== | ==Построение== | ||
===Описание алгоритма=== | ===Описание алгоритма=== | ||
− | Расположим вершины на окружности так, чтобы они | + | Расположим вершины на окружности так, чтобы они являлись вершинами правильного многоугольника, и выберем начальную вершину (рис.<tex>1</tex>). Для <tex>\left \lfloor {\dfrac{n}{2}}\right \rfloor</tex> вершин по часовой стрелке, начиная с этой вершины, будем строить остовные деревья. Для <tex>i</tex>-ой вершины строим такой путь <tex>:</tex><tex>V_i V_{i+1} V_{i-1} V_{i+2} V_{i-2}\ldots, </tex> {{---}} до тех пор, пока не соединим все вершины. Это и будет остовным деревом. (рис.<tex>2-3</tex>) |
{| cellpadding="10" | {| cellpadding="10" | ||
|- | |- | ||
|[[Файл:Max spanning tree1.png|thumb|300px|center|Рис.1 Стрелкой указана начальная вершина]] || [[Файл:Max spanning tree2.png|thumb|339px|center|Рис.2 Красным цветом выделено первое построенное остовное дерево]] || [[Файл:Max spanning tree6.png|thumb|270px|center|Рис.3 Все остовные деревья]] | |[[Файл:Max spanning tree1.png|thumb|300px|center|Рис.1 Стрелкой указана начальная вершина]] || [[Файл:Max spanning tree2.png|thumb|339px|center|Рис.2 Красным цветом выделено первое построенное остовное дерево]] || [[Файл:Max spanning tree6.png|thumb|270px|center|Рис.3 Все остовные деревья]] | ||
− | |} | + | |} |
===Доказательство корректности=== | ===Доказательство корректности=== |
Версия 00:47, 17 декабря 2017
Содержание
Попарно непересекающиеся остовные деревья
Утверждение: |
Максимальное количество попарно непересекающихся остовных деревьев в графе с вершинами не более |
Очевидно, что среди графов с | вершинами наибольшее количество непересекающихся остовных деревьев может быть только в полном графе. Количество ребер в таком графе равно , а в каждом дереве ребро. Значит, в полном графе мы сможем построить не более остовных деревьев.
Построение
Описание алгоритма
Расположим вершины на окружности так, чтобы они являлись вершинами правильного многоугольника, и выберем начальную вершину (рис.
). Для вершин по часовой стрелке, начиная с этой вершины, будем строить остовные деревья. Для -ой вершины строим такой путь — до тех пор, пока не соединим все вершины. Это и будет остовным деревом. (рис. )Доказательство корректности
Докажем, что построенные с помощью такого алгоритма остовные деревья будут попарно непересекающимися. Для этого докажем, что никакие ребра не совпадут. Ребра могут совпасть только в том случае, если дуги, на которые эти ребра опираются, будут одинаковой длины. Заметим, что при построении каждого последующего дерева его ребра получаются из поворотов ребер предыдущего на длину , где — длина окружности. Рассмотрим первое построенное остовное дерево.(рис. ) В нем не более -х ребер имеют одинаковую длину дуги (длина дуги у ребра, расположенного на диаметре окружности, не совпадает с длиной дуги любого другого ребра данного остовного дерева). Значит, повороты только этих ребер могут совпасть между собой.- Докажем, что повороты ребра, расположенного на диаметре окружности, не совпадут друг с другом (если
Чтобы хоть какой-то поворот совпал, мы должны повернуть ребро на . Каждый раз мы поворачиваем ребро на . А так как мы поворачиваем ребро раз, то в сумме мы повернем его на
. А это значит, что никакие ребра не совпадут друг с другом. (рис. )
нечетно, то такого ребра не будет). - Докажем для остальных ребер. (рис.
Возьмем ребро, которое не лежит на диаметре окружности. В данном остовном дереве есть ребро, которое имеет такую же длину дуги. Ориентируем данные ребра в сторону часовой стрелки. Чтобы повороты этих ребер совпали, нужно, чтобы совпали их начала и концы. Покажем, что их начала никогда не совпадут. Чтобы начало первого ребра совпало с началом второго, нужно первое ребро повернуть хотя бы на половину длины окружности, то есть на . Для этого нам нужно сделать поворотов: . Но мы делаем только поворот. Аналогично с поворотом второго ребра. Для нечетных граф будет неполным, поэтому даже поворотов может не хватить для совпадения ребер. )
См. также
- Остовные деревья: определения, лемма о безопасном ребре
- Остовное дерево в планарном графе
- Минимально узкое остовное дерево
Источники информации
- Карпов Д. В. — Теория графов, стр 297