Мост (теория графов): различия между версиями
[отпатрулированная версия] | [отпатрулированная версия] |
отмена правки 87378255 участника 31.134.191.119 (обс.), немотивированное удаление текста Метка: отмена |
Klimenkov (обсуждение | вклад) Поправил ссылку на "Разложение на уши" |
||
(не показано 7 промежуточных версий 6 участников) | |||
Строка 19: | Строка 19: | ||
Граф с <math>n</math> вершинами может содержать не более <math>n-1</math> мостов, поскольку добавление ещё одного ребра неминуемо приведёт к появлению цикла. Графы, имеющие в точности <math>n-1</math> мостов, известны как [[Дерево (теория графов)|деревья]], а графы, в которых любое ребро является мостом — это [[Дерево (теория графов)|леса]]. |
Граф с <math>n</math> вершинами может содержать не более <math>n-1</math> мостов, поскольку добавление ещё одного ребра неминуемо приведёт к появлению цикла. Графы, имеющие в точности <math>n-1</math> мостов, известны как [[Дерево (теория графов)|деревья]], а графы, в которых любое ребро является мостом — это [[Дерево (теория графов)|леса]]. |
||
В любом неориентированном графе существует [[отношение эквивалентности]] [[Вершина (теория графов)|вершин]], согласно которому две вершины эквивалентны, если существует |
В любом неориентированном графе существует [[отношение эквивалентности]] [[Вершина (теория графов)|вершин]], согласно которому две вершины эквивалентны, если существует два соединяющих их пути, которые не пересекаются по рёбрам (любая вершина считается эквивалентной себе). Классы эквивалентности этого отношения называются '''рёберно 2-связными компонентами''' и мосты графа — это в точности те рёбра, концы которых принадлежат различным компонентам. '''Мостовая блок-схема''' графа имеет вершину для любой нетривиальной компоненты и ребро для каждого моста<ref>{{статья |
||
| автор = Jeffery Westbrook, Robert E. Tarjan |
| автор = Jeffery Westbrook, Robert E. Tarjan |
||
| doi = 10.1007/BF01758773 |
| doi = 10.1007/BF01758773 |
||
Строка 37: | Строка 37: | ||
== Графы без мостов == |
== Графы без мостов == |
||
Как понятно из названия, '''граф без мостов''' — это граф, в котором нет мостов. Эквивалентные условия — что каждая [[Компонента связности графа|компонента связности]] графа имеет |
Как понятно из названия, '''граф без мостов''' — это граф, в котором нет мостов. Эквивалентные условия — что каждая [[Компонента связности графа|компонента связности]] графа имеет открытое [[Ушная декомпозиция|ушное разложение]]<ref name="robbins39">{{статья |
||
| автор = H. E. Robbins |
| автор = H. E. Robbins |
||
| издание = [[The American Mathematical Monthly]] |
| издание = [[The American Mathematical Monthly]] |
||
| страницы = 281—283 |
| страницы = 281—283 |
||
| заглавие = A theorem on graphs, with an application to a problem of traffic control |
| заглавие = A theorem on graphs, with an application to a problem of traffic control |
||
| ссылка = https://archive.org/details/sim_american-mathematical-monthly_1939_46/page/281 |
|||
| том = 46 |
| том = 46 |
||
| год = 1939}}</ref>, что каждая связная компонента является [[Рёберно k-связный граф|рёберно 2-связной]] или (по [[Теорема Роббинса|теореме Роббинса]]) что каждая связная компонента имеет {{не переведено 5|Строгая ориентация|строгую ориентацию||strong orientation}}<ref name="robbins39"/>. |
| год = 1939}}</ref>, что каждая связная компонента является [[Рёберно k-связный граф|рёберно 2-связной]] или (по [[Теорема Роббинса|теореме Роббинса]]) что каждая связная компонента имеет {{не переведено 5|Строгая ориентация|строгую ориентацию||strong orientation}}<ref name="robbins39"/>. |
||
Важной открытой проблемой, связанной с мостами, является [[Двойное покрытие циклами|гипотеза о двойном покрытии циклами]], высказанная |
Важной открытой проблемой, связанной с мостами, является [[Двойное покрытие циклами|гипотеза о двойном покрытии циклами]], высказанная [[Сеймур, Пол (математик)|Сеймуром]] и [[Секереш, Дьёрдь|Секерешем]] (в 1978 году и 1979 году, независимо), которая утверждает, что любой граф без мостов можно покрыть простыми циклами, содержащими каждое ребро дважды<ref>{{книга |
||
| автор = F. Jaeger |
| автор = F. Jaeger |
||
| вклад = A survey of the cycle double cover conjecture |
| вклад = A survey of the cycle double cover conjecture |
||
Строка 67: | Строка 68: | ||
* Находим [[остовный лес]] графа <math>G</math>. |
* Находим [[остовный лес]] графа <math>G</math>. |
||
* Создаём лес с корнями <math>F</math> из остовного дерева. |
* Создаём лес с корнями <math>F</math> из остовного дерева. |
||
* Обходим лес <math>F</math> в |
* Обходим лес <math>F</math> в [[Обход дерева|прямом порядке]] и нумеруем вершины. Родительские вершины теперь имеют меньшие номера по сравнению с потомками. |
||
Будем обозначать ребро (v,w), содержащееся в дереве, как <math>v\to w</math>, а не содержащееся — как <math>v--w</math>. |
Будем обозначать ребро (v,w), содержащееся в дереве, как <math>v\to w</math>, а не содержащееся — как <math>v--w</math>. |
||
Строка 76: | Строка 77: | ||
** Вычисляем <math>L(v)</math>, минимальный номер, до которого можно дойти из вершины <math>v</math>, идя по рёбрам поддерева, начинающегося в <math>v</math> (за исключением последнего ребра). Это минимальный номер в множестве, состоящем из значений <math>L(w)</math> потомков вершины <math>v</math> и номеров вершин, до которых можно дойти из <math>v</math> по рёбрам, не принадлежащим <math>F</math>. |
** Вычисляем <math>L(v)</math>, минимальный номер, до которого можно дойти из вершины <math>v</math>, идя по рёбрам поддерева, начинающегося в <math>v</math> (за исключением последнего ребра). Это минимальный номер в множестве, состоящем из значений <math>L(w)</math> потомков вершины <math>v</math> и номеров вершин, до которых можно дойти из <math>v</math> по рёбрам, не принадлежащим <math>F</math>. |
||
<math>L(v) = \min(\{v\} \cup \{L( |
<math>L(v) = \min(\{v\} \cup \{L(w) \mid v \to w\} \cup \{w \mid v--w\})</math> |
||
** Аналогичным образом вычислим <math>H(v)</math>, наибольший номер, до которого можно добраться, идя по рёбрам поддерева, начинающегося <math>v</math>. Это максимальный номер в множестве значений, состоящем из значений <math>H(w)</math> потомков вершины <math>v</math> и номеров вершин, до которых можно дойти из <math>v</math> по рёбрам, не принадлежащим <math>F</math>. |
** Аналогичным образом вычислим <math>H(v)</math>, наибольший номер, до которого можно добраться, идя по рёбрам поддерева, начинающегося <math>v</math>. Это максимальный номер в множестве значений, состоящем из значений <math>H(w)</math> потомков вершины <math>v</math> и номеров вершин, до которых можно дойти из <math>v</math> по рёбрам, не принадлежащим <math>F</math>. |
||
<math>H(v) = \max(\{v\} \cup \{H( |
<math>H(v) = \max(\{v\} \cup \{H(w) \mid v \to w\} \cup \{w \mid v--w\})</math> |
||
** Для каждой вершины <math>w</math> с родителем <math>v</math> проверяем, если <math>L(w) = w</math> и <math>H(w) < w + ND(w)</math>, то ребро из <math>v</math> в <math>w</math> является мостом. |
** Для каждой вершины <math>w</math> с родителем <math>v</math> проверяем, если <math>L(w) = w</math> и <math>H(w) < w + ND(w)</math>, то ребро из <math>v</math> в <math>w</math> является мостом. |
||
Строка 106: | Строка 107: | ||
# ''G'' является рёберно 2-связным в том и только в том случае, когда цепочки ''C'' содержат все рёбра из ''E''. |
# ''G'' является рёберно 2-связным в том и только в том случае, когда цепочки ''C'' содержат все рёбра из ''E''. |
||
# Ребро ''e'' в ''G'' является мостом в том и только в том случае, когда ''e'' не содержится ни в одной цепочке из ''C''. |
# Ребро ''e'' в ''G'' является мостом в том и только в том случае, когда ''e'' не содержится ни в одной цепочке из ''C''. |
||
# Если ''G'' является рёберно 2-связным, ''C'' является |
# Если ''G'' является рёберно 2-связным, ''C'' является [[Ушная декомпозиция|разложением на уши]]. |
||
# ''G'' является вершинно 2-связным в том и только в том случае, когда ''G'' имеет минимальную степень 2 и ''C<sub>1</sub>'' является единственным циклом в ''C''. |
# ''G'' является вершинно 2-связным в том и только в том случае, когда ''G'' имеет минимальную степень 2 и ''C<sub>1</sub>'' является единственным циклом в ''C''. |
||
# Вершина ''v'' в рёберно 2-связном графе ''G'' является шарниром в том и только в том случае, когда ''v'' является первой вершиной в цикле из ''C - C<sub>1</sub>''. |
# Вершина ''v'' в рёберно 2-связном графе ''G'' является шарниром в том и только в том случае, когда ''v'' является первой вершиной в цикле из ''C - C<sub>1</sub>''. |
Текущая версия от 21:26, 21 мая 2022
Мост — ребро в теории графов, удаление которого увеличивает число компонент связности[1]. Такие рёбра также известны как разрезающие рёбра, разрезающие дуги или перешейки. Эквивалентное определение — ребро является мостом в том и только в том случае, если оно не содержится ни в одном цикле.
Деревья и леса
[править | править код]Граф с вершинами может содержать не более мостов, поскольку добавление ещё одного ребра неминуемо приведёт к появлению цикла. Графы, имеющие в точности мостов, известны как деревья, а графы, в которых любое ребро является мостом — это леса.
В любом неориентированном графе существует отношение эквивалентности вершин, согласно которому две вершины эквивалентны, если существует два соединяющих их пути, которые не пересекаются по рёбрам (любая вершина считается эквивалентной себе). Классы эквивалентности этого отношения называются рёберно 2-связными компонентами и мосты графа — это в точности те рёбра, концы которых принадлежат различным компонентам. Мостовая блок-схема графа имеет вершину для любой нетривиальной компоненты и ребро для каждого моста[2].
Связь с вершинной связностью
[править | править код]Мосты тесно связаны с концепцией шарниров — вершин, которые входят в любой путь, соединяющий некоторые две вершины. Две конечные вершины моста являются шарнирами, если они не имеют степень 1, хотя рёбра, не являющиеся мостами, тоже могут с обоих концов иметь шарниры. Аналогично графам без мостов, которые рёберно 2-связны, графы без шарниров вершинно 2-связны.
В кубических графах любой шарнир является конечной вершиной хотя бы одного моста.
Графы без мостов
[править | править код]Как понятно из названия, граф без мостов — это граф, в котором нет мостов. Эквивалентные условия — что каждая компонента связности графа имеет открытое ушное разложение[3], что каждая связная компонента является рёберно 2-связной или (по теореме Роббинса) что каждая связная компонента имеет строгую ориентацию[англ.][3].
Важной открытой проблемой, связанной с мостами, является гипотеза о двойном покрытии циклами, высказанная Сеймуром и Секерешем (в 1978 году и 1979 году, независимо), которая утверждает, что любой граф без мостов можно покрыть простыми циклами, содержащими каждое ребро дважды[4].
Алгоритм поиска мостов Тарьяна
[править | править код]Первый алгоритм для нахождения мостов в графе, имеющий линейное время работы, описан Робертом Тарьяном в 1974 году[5]. Алгоритм работает следующим образом:
- Находим остовный лес графа .
- Создаём лес с корнями из остовного дерева.
- Обходим лес в прямом порядке и нумеруем вершины. Родительские вершины теперь имеют меньшие номера по сравнению с потомками.
Будем обозначать ребро (v,w), содержащееся в дереве, как , а не содержащееся — как .
- Для каждой вершины при прямом обходе выполняем:
- Вычисляем число потомков для вершины, добавляя единицу при переходе к следующей вершине (включая вершину ).
.
- Вычисляем , минимальный номер, до которого можно дойти из вершины , идя по рёбрам поддерева, начинающегося в (за исключением последнего ребра). Это минимальный номер в множестве, состоящем из значений потомков вершины и номеров вершин, до которых можно дойти из по рёбрам, не принадлежащим .
- Аналогичным образом вычислим , наибольший номер, до которого можно добраться, идя по рёбрам поддерева, начинающегося . Это максимальный номер в множестве значений, состоящем из значений потомков вершины и номеров вершин, до которых можно дойти из по рёбрам, не принадлежащим .
- Для каждой вершины с родителем проверяем, если и , то ребро из в является мостом.
Если — мост, то ясно, что из поддерева с корнем в не должно быть возможности выйти на вершину, не принадлежащую этому поддереву. Для проверки этого достаточно проверить L(w),H(w) — условие означает, что мы не выйдем на вершину, лежащую ближе к корню, а условие — что мы не выйдем на другое поддерево.
Поиск мостов с помощью разложения на цепочки
[править | править код]Очень простой алгоритм поиска мостов[6] опирается на разложение на цепи. Разложение на цепи не только позволяет получить все мосты, оно также даёт возможность получить все шарниры (и двусвязные компоненты) графа G, давая тем самым базу для проверки рёберной и вершинной 2-связности (и этот метод можно распространить на линейную по времени проверку рёберной и вершинной 3-связности).
Разложение на цепочки — это специальный случай разложения на уши, основанный на поиске в глубину по дереву T графа G и оно может быть выполнено очень просто:
пусть все вершины помечены как непосещённые. Для всех вершин v в восходящем порядке номеров обхода 1...n, проходим каждое обратное ребро (то есть ребро, не принадлежащее дереву обхода), инцидентное вершине v, и проследуем по рёбрам дерева к корню пока не встретим посещённую вершину. Во время этого прохода помечаем все пройденные вершины как посещённые. Этот проход закончится образованием либо пути, либо цикла, начинающегося в v, мы назовём это путь или цикл цепочкой. Будем обозначать i-ю цепочку, полученную такой процедурой, как Ci. C=C1,C2,... является тогда разбиением графа G на цепочки.
Следующие свойства дают возможность получить некоторую информацию о графе G из C эффективно, включая все мосты[6]:
Пусть C — разложение на цепочки простого связного графа G=(V,E).
- G является рёберно 2-связным в том и только в том случае, когда цепочки C содержат все рёбра из E.
- Ребро e в G является мостом в том и только в том случае, когда e не содержится ни в одной цепочке из C.
- Если G является рёберно 2-связным, C является разложением на уши.
- G является вершинно 2-связным в том и только в том случае, когда G имеет минимальную степень 2 и C1 является единственным циклом в C.
- Вершина v в рёберно 2-связном графе G является шарниром в том и только в том случае, когда v является первой вершиной в цикле из C - C1.
- Если G является вершинно 2-связным, C является открытым разложением на уши[англ.].
Примечания
[править | править код]- ↑ Béla Bollobás. Modern Graph Theory. — New York: Springer-Verlag, 1998. — Т. 184. — С. 6. — (Graduate Texts in Mathematics). — ISBN 0-387-98488-7. — doi:10.1007/978-1-4612-0619-4.
- ↑ Jeffery Westbrook, Robert E. Tarjan. Maintaining bridge-connected and biconnected components on-line // Algorithmica. — 1992. — Т. 7, вып. 5—6. — С. 433—464. — doi:10.1007/BF01758773.
- ↑ 1 2 H. E. Robbins. A theorem on graphs, with an application to a problem of traffic control // The American Mathematical Monthly. — 1939. — Т. 46. — С. 281—283.
- ↑ F. Jaeger. Annals of Discrete Mathematics 27 — Cycles in Graphs. — 1985. — Т. 27. — С. 1—12. — (North-Holland Mathematics Studies). — doi:10.1016/S0304-0208(08)72993-1.
- ↑ R. Endre Tarjan. A note on finding the bridges of a graph // Information Processing Letters. — Т. 2, вып. 6. — С. 160—161. — doi:10.1016/0020-0190(74)90003-9.
- ↑ 1 2 Jens M. Schmidt. A Simple Test on 2-Vertex- and 2-Edge-Connectivity // Information Processing Letters. — 2013. — Т. 113, вып. 7. — С. 241—244. — doi:10.1016/j.ipl.2013.01.016.
Для улучшения этой статьи желательно:
|