disc_lekcii
.pdfТеорема || Из всякого незамкнутого маршрута (пути) можно выделить простую
цепь с теми же начальной и конечной вершинами. Доказательство || аналогично предыдущему. Определение. Композицией путей (маршрутов)
Π1=v1x1v2...xk-1vk, Π2=vkxkvk+1...xL-1vL называется путь (маршрут)
Π1 oΠ2=v1x1v2...xk-1vkxkvk+1xk+1...xL-1vL.
Матрицы смежности и инцидентности
Пусть D=(V,X) орграф, V={v1,...,vn}, X={x1,...,xm}.
Матрицей смежности орграфа D называется квадратная матрица
A(D)=[aij] порядка n, где
a |
|
1, |
(vi ,v j) X |
ij |
= |
(vi ,v j) X |
|
|
0, |
||
|
|
|
|
Матрицей инцидентности называется матрица B(D)=[bij] порядка n×m, |
|||
где |
|
|
|
|
|
|
vi − конецдуги x j, |
|
|
1, |
|
bij = −1, |
vi − на÷алодуги x j, |
||
|
|
|
vi − неинцидентнадуге x j. |
|
|
0, |
Для неориентированных графов G=(V,X)
Матрицей смежности графа G называется квадратная симметричная матрица A(G)=[aij] порядка n, где
|
|
|
|
|
|
{vi ,v j} X |
|
|
|
|
a |
|
1, |
|
|
|
|
|
|
||
ij |
= |
|
|
|
{vi ,v j} X |
|
|
|
|
|
|
0, |
|
|
|
|
|
|
|||
|
|
|
|
|
|
|
|
|
|
|
Матрицей инцидентности графа G называется матрица B(G)=[bij] |
||||||||||
порядка n×m, где |
|
|
|
|
||||||
|
|
1, |
v |
i |
−инцидентна ребру x |
j |
, |
|
|
|
bij |
|
|
|
|
|
|
||||
= |
v |
|
−неинцидентна ребру |
x |
|
. |
||||
|
|
0, |
i |
j |
||||||
|
|
|
|
|
|
|
|
|
Примеры.
1. Для орграфа, изображенного на рис.
x1 |
|
|
|
|
|
|
|
|
|
|
υ1 |
|
|
υ2 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
x |
4 |
|
|
|
|
|
|
|
|
|
x3 |
|
x |
2 |
|
|
|
|
|
|
|
υ3 |
|
υ1 |
υ2 |
υ3 |
|
|
x1 |
x2 |
x3 |
x4 |
|
|
|
|
|||||||
A(D) = |
υ1 |
0 |
1 |
0 |
B(D) = |
υ1 |
−1 |
0 |
1 |
1 |
|
υ2 |
1 |
0 |
1 |
|
υ2 |
1 −1 0 −1 |
|||
|
υ3 |
1 |
0 |
0 |
|
υ3 |
0 |
1 −1 0 |
2.Для графа, изображенного на рис.
υ2
x1
υ1 |
υ3 |
|
x |
||
2 |
|
|
υ1 |
υ2 |
υ3 |
|
|
|
x1 |
x2 |
A(G) = |
υ1 |
0 |
1 |
1 |
, |
B(G) = |
υ1 |
1 |
1 |
|
υ2 |
1 |
0 |
0 |
|
|
υ2 |
1 |
0 |
|
υ3 |
1 |
0 |
0 |
|
|
υ3 |
0 |
1 |
Ориентированный псевдограф
υ2
υ1
D
υ3
|
|
υ1 |
υ2 |
υ3 |
A(D) = |
υ1 |
1 |
2 |
0 |
|
υ2 |
0 |
0 |
0 |
|
υ3 |
2 |
3 |
2 |
С помощью этих матриц графы задаются на ЭВМ.
Свойства матриц смежности и инцидентности.
Для ориентированного мультиграфа D=(V,X), V={v1,...,vn}, X={x1,...,xm}
n
∑aij = δ+(vi ) j=1
∑n aij = δ−(v j) i=1
-сумма строк матрицы B(D) является нулевой строкой (дуга один раз входит и один раз выходит);
-любая строка матрицы B(D) является линейной комбинацией остальных строк (вследствие предыдущего);
-ранг матрицы B(D) не превосходит n(D)-1 (также вследствие предыдущего);
-для любого контура в D сумма столбцов матрицы B(D), соответствующих дугам, входящим в этот контур, равна нулевому столбцу.
Для |
неориентированного мультиграфа G=(V,X), V={v1,...,vn}, |
X={x1,...,xm} |
|
n |
n |
∑aij = ∑aij = δ(vi ) |
|
j=1 |
i=1 |
-сумма строк матрицы B(G) по модулю 2 является нулевой строкой (дуга один раз входит и один раз выходит, а вместе четно);
-любая строка матрицы B(G) является суммой по модулю 2 остальных строк (вследствие предыдущего);
-для любого цикла в G сумма по модулю 2 столбцов матрицы B(G), соответствующих ребрам, входящим в этот цикл, равна нулевому столбцу.
Определение. Матрица C=[cij], у которой cij {0,1} наз. булевой. Если G – псевдограф без кратных ребер, матрица смежности – булева.
Лекция 9
Связность. Компоненты связности
Определения.
Подграфом графа G называется граф, все вершины и ребра которого содержатся среди вершин и ребер графа G. (Для орграфа то же).
Подграф наз. собственным, если он отличен от самого графа. Говорят, что вершина w орграфа D (графа G) достижима из верш. v,
если либо w=v, либо существует путь (маршрут) из v в w.
Граф (орграф) наз связным (сильно связным), если для любых двух его вершин v, w существует маршрут (путь), соединяющий v и w.
Орграф наз односторонне связным, если для любых двух его вершин по крайней мере одна достижима из другой.
Псевдографом, ассоциированным с ориентированным псевдографом D=(V,X) наз. псевдограф G=(V,X0), в котором X0 получается из X заменой всех упорядоченных пар (v,w) на неупорядоченные {v,w}.
Орграф наз слабо связным, если связным является ассоциированный с ним псевдограф.
Если граф (орграф) не является связным (слабо связным), то он наз. несвязным.
Компонентой связности графа G (сильной связности орграфа D) наз. его связный (сильно связный) подграф, не являющийся собственным подграфом никакого другого связного (сильно связного) подграфа графа G (орграфа D).
Примеры.
Матрицы достижимости и связности
Пусть A(D) – матрица смежности ориентированного псевдографа
D=(V,X) (или псевдографа G=(V,X)), где V={v1,…, vn}. Обозначим через Ak=[a(k)ij] k-ю степень матрицы смежности A(D).
Утверждение. Элемент a(k)ij матрицы Ak ориентированного псевдографа D=(V,X) (псевдографа G=(V,X)) равен числу всех путей (мапшрутов) длины k из vi в vj.
Д-во
Для k=1 очевидно в силу построения матрицы A(D).
Пусть это справедливо для n=k-1. Т.е. в матрице Ak-1 в i-той строке на l-том месте стоит число, означающее кол-во маршрутов из vi в vl длины k−1. Столбец под номером j матрицы A содержит числа, означающие колво дуг (ребер) из vl в vj (l-номер строки). Тогда скалярное произведение i- той строки матрицы Ak-1 на j-тый столбец матрицы A равен сумме произведений. Каждое произведение означает кол-во путей из vi в vj, проходящих через vl на предпоследнем шаге. В сумме получается общее кол-во.
Утверждение. Для того, чтобы n-вершинный орграф D с матрицей смежности A=A(D) имел хотя бы один контур, чтобы матрица K=A2+A3+… An имела ненулевые диагональные элементы (следствие предыдущего).
Пусть ρ-отношение достижимости на множестве V всех вершин (неориентированного) графа G. (либо v=w, либо маршрут, соединяющий v и w).
Тогда
1)ρ-отношение эквивалентности;
2)vρw вершины v,w принадлежат одной компоненте связности;
3)для класса эквивалентности V1 псевдограф G1, порожденный множеством V1, является компонентой связности псевдографа G.
Для орграфа.
Пусть ρ1-отношение достижимости на множестве V всех вершин ориентированного псевдографа D. Пусть ρ2-отношение двусторонней достижимости на множестве V. (ρ2=ρ1∩ρ1-1). Тогда
1)ρ1 - рефлексивно, транзитивно;
2)ρ2 – эквивалентность на V;
3)vρ2w когда вершины v,w одной компоненте сильной связности;
4)для класса эквивалентности V1 ориент. псевдограф D1, порожденный множеством V1, является компонентой связности ор. псевдографа G.
Число компонент связности орграфа D обозначается P(D). (для неор. - P(G).
Определение. Под операцией удаления вершины из графа (орграфа) будем понимать операцию, заключающуюся в удалении некоторой вершины вместе с с инцидентными ей ребрами (дугами).
Определение. Вершина графа, удаление которой увеличивает число компонент связности, называется точкой сочленения.
Пример.
Утверждение. Если D' – орграф, полученный в результате удаления нескольких вершин из орграфа D, то A(D') получается из A(D) в результате удаления строк и столбцов, соответствующих удаленным вершинам. (Для неор. графа то же самое).
Определение. Матрицей достижимости орграфа D называется квадратная матрица T(D)=[tij] порядка n, элементы которой равны
|
1, |
v |
j |
достижима из v |
i |
, |
tij |
|
|
|
|
||
= |
|
|
|
|
|
|
|
|
в |
|
противном случае. |
||
|
0 |
|
Определение. Матрицей сильной связности орграфа D называется квадратная матрица S(D)=[sij] порядка n, элементы которой равны
1, |
v |
j |
достижима из v |
i |
и |
v |
i |
достижима из v |
j |
|
|
|
|
|
|
||||
sij = |
|
|
|
|
|
|
|
|
|
|
|
|
в противном |
|
|
случае. |
|
||
0 |
|
|
|
|
|
Определение. Матрицей связности графа G называется квадратная матрица S(G)=[sij] порядка n, элементы которой равны
|
1, если |
маршрут, соединяющий v |
j |
и |
v |
i |
, |
sij |
|
|
|
|
|
||
= |
|
|
|
|
|
|
|
|
|
в противном случае. |
|
|
|
|
|
|
0 |
|
|
|
|
|
Утверждение. Пусть G=(V,X) – граф, V={v1,…, vn}, A(G) – его матрица смежности. Тогда
S(G)=sign[E+A+A2+A3+… An-1] (E- единичная матрица порядка n). (Следует из предыдущего).
Утверждение. Пусть D=(V,X) – орграф, V={v1,…, vn}, A(D) – его матрица смежности. Тогда
1)T(D)=sign[E+A+A2+A3+… An-1],
2)S(D)=T(D)&TT(D) (TT-транспонированная матрица, &- поэлементное умножение).
Алгоритм выделения компонент сильной связности.
1.Присваиваем p=1, S1=S(D).
2.Включаем в множество вершин Vp компоненты сильной связности Dp вершины, соответствующие единицам первой строки матрицы Sp. В качестве матрицы A(Dp) возьмем подматрицу матрицы A(D), состоящую из элементов матрицы A, находящихся на пересечении строк и столбцов, соответствующих вершинам из Vp.
3.Вычеркиваем из Sp строки и столбцы, соответствующие вершинам из Vp. Если не остается ни одной строки (и столбца), то p- кол-во компонент сильной связности. В противном случае обозначим оставшуюся
после вычеркивания срок и столбцов матрицу Sp+1, присваиваем p:=p+1 и переходим к п. 2.
Пример.
|
0 |
0 |
1 |
0 |
0 |
|
|
0 |
0 |
0 |
0 |
0 |
|
|
|
|||||
A(D)= |
0 |
1 |
0 |
1 |
1 , |
|
|
0 |
1 |
0 |
0 |
0 |
|
|
|
|||||
|
1 |
0 |
0 |
1 |
0 |
|
|
|
|
|
0 |
0 |
1 |
0 |
0 |
0 |
0 |
1 |
0 |
0 |
|
0 |
1 |
0 |
1 |
1 |
|
|||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
0 |
0 |
0 |
0 |
0 |
|
0 |
0 |
0 |
0 |
0 |
|
|
0 |
0 |
0 |
0 |
0 |
|
|
A2 |
|
|
|
|
|
, |
|||||||||||||||
= |
0 |
1 |
0 |
1 |
1 |
|
0 |
1 |
0 |
1 |
1 |
|
= |
1 |
1 |
0 |
1 |
0 |
|
||
|
|
0 |
1 |
0 |
0 |
0 |
|
0 |
1 |
0 |
0 |
0 |
|
|
0 |
0 |
0 |
0 |
0 |
|
|
|
|
|
|
|
|
|
|||||||||||||||
|
|
1 |
0 |
0 |
1 |
0 |
|
1 |
0 |
0 |
1 |
0 |
|
|
0 |
1 |
1 |
0 |
0 |
|
|
|
|
|
|
|
|
|
|
0 1 0 1 1 |
|
0 |
0 |
1 |
0 |
0 |
|
1 |
1 |
|
|
0 1 0 |
|
|
||||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
0 |
0 |
0 0 |
0 |
|
0 |
0 |
0 |
0 |
0 |
|
|
0 |
0 |
|
|
0 0 0 |
|
|
|
||
|
|
|
|
|
|
|
|
, |
|
||||||||||||||
A3 |
= A2 A = |
1 |
1 |
0 1 |
0 |
|
0 |
1 |
0 |
1 |
1 |
|
= |
0 |
1 |
|
|
1 0 0 |
|
|
|||
|
|
0 |
0 |
0 0 |
0 |
|
0 |
1 |
0 |
0 |
0 |
|
|
0 |
0 |
|
|
0 0 0 |
|
|
|
||
|
|
|
|
|
|
|
|
|
|
||||||||||||||
|
|
0 |
1 |
1 0 |
0 |
|
1 |
0 |
0 |
1 |
0 |
|
|
0 |
1 |
|
|
0 1 1 |
|
|
|
||
|
|
|
|
|
|
|
|
|
|
||||||||||||||
|
1 1 0 1 0 |
|
0 |
0 |
1 |
0 |
0 |
|
0 |
1 |
|
|
1 0 0 |
|
|
||||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
0 |
0 |
0 0 |
0 |
|
0 |
0 |
0 |
0 |
0 |
|
|
0 |
0 |
|
|
0 0 0 |
|
|
|
||
|
|
|
|
|
|
|
|
, |
|
||||||||||||||
A4 |
= A3 A = |
0 |
1 |
1 0 |
0 |
|
0 |
1 |
0 |
1 |
1 |
|
= |
0 |
1 |
|
|
0 1 1 |
|
|
|||
|
|
0 |
0 |
0 0 |
0 |
|
0 |
1 |
0 |
0 |
0 |
|
|
0 |
0 |
|
|
0 0 0 |
|
|
|
||
|
|
|
|
|
|
|
|
|
|
||||||||||||||
|
|
0 |
1 |
0 1 |
1 |
|
1 |
0 |
0 |
1 |
0 |
|
|
1 |
1 |
|
|
0 1 0 |
|
|
|
||
|
|
|
|
|
|
|
|
|
|
||||||||||||||
|
|
|
|
|
|
|
|
|
|
1 1 |
1 |
1 |
1 |
|
|
|
|
||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
0 1 |
0 |
0 |
0 |
|
|
|
|
|
||||
|
|
|
|
2 |
|
|
3 |
|
4 |
|
|
, |
|
|
|
||||||||
T(D)=sign[E+A+A +A +A ]= |
1 1 |
1 |
1 |
1 |
|
|
|
|
|||||||||||||||
|
|
|
|
|
|
|
|
|
|
|
0 1 |
0 |
1 |
0 |
|
|
|
|
|
||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
||||||||
|
|
|
|
|
|
|
|
|
|
|
1 1 |
1 |
1 |
1 |
|
|
|
|
|
||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
||||||||
|
|
|
1 1 1 1 1 |
1 0 1 0 1 |
|
|
1 0 1 0 1 |
||||||||||||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
T |
0 1 0 0 0 |
|
1 1 1 1 1 |
= |
|
0 1 0 0 0 |
|
||||||||||||||
S(D)=T&T |
= 1 1 1 |
|
1 |
1 |
1 |
0 |
1 |
|
0 |
1 |
|
1 |
0 1 |
|
0 1 |
. |
|||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
0 0 0 1 0 |
|
|||||
|
|
|
0 1 0 1 0 |
|
1 0 1 1 1 |
|
|
|
|||||||||||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 0 1 0 1 |
|
|||||
|
|
|
1 1 1 1 1 |
|
1 0 1 0 1 |
|
|
|
Выделение компонент связности.
|
|
1 |
0 |
1 |
0 |
1 |
||
|
|
|
0 |
1 |
0 |
0 |
0 |
|
1. p=1, |
|
|
|
|||||
S1 = S = |
|
1 |
0 |
1 |
0 |
1 |
|
|
|
|
|||||||
|
|
|
0 |
0 |
0 |
1 |
0 |
|
|
|
|
1 |
0 |
1 |
0 |
1 |
|
|
|
|
|
0 1 0
2. V1={v1, v3, v5}, A(D1 )= 0 0 1
1 0 0
D1
3. |
S 2 |
1 |
0 |
|
, |
|
= |
|
|
|
|||
|
|
|
0 |
1 |
|
|
|
|
|
|
|
2'. V2={v2 }, A(D2 )= (1)
D2
3. S1 = (1),
D3
Лекция №10
Задача поиска маршрутов в графе (путей в орграфе)
Алгоритм Тэрри поиска маршрута в связном графе, соединяющего вершины υ и ω υ ≠ ω.
Правила.
1)Идя по произвольному ребру всегда отмечать направление его прохождения.
2)Исходя из некоторой вершины υ′ всегда следовать по тому ребру,
которое не было пройдено или было пройдено в противоположном направлении.
3) Для всякой вершины υ′ ≠ υ отмечать ребро по которому в вершину υ′попали в первый раз
4) Исходя из некоторой вершины υ′ ≠ υ идти по первому заходящему в υ′ ребру лишь тогда, когда нет других возможностей.
|
|
υ |
|
υ |
Найти маршрут |
|
+ |
|
соед. υ1 и υ5 |
||
|
|
3 |
+4 |
||
|
|
|
|
|
+, значит |
υ2 |
|
|
|
|
прошли |
|
|
|
|
|
|
+ |
|
|
|
|
|
|
υ1 |
|
|
υ5 |
|
Замечание: из полученного пути можно выделить простую цепь.
Поиск оптимального пути (маршрута) (т.е пути с наименьшим числом дуг или ребер)
Утверждения:
1) каждый минимальный путь (маршрут) является простой цепью Доказательство.
Пусть |
П = υ1υ2 ...υk υ1 |
≠ υk минимальный |
путь в орграфе D, не |
|||||
являющийся простой цепью. Тогда i и j такие, |
что 1 ≤ i < j ≤ k |
и vi=vj. |
||||||
Рассмотрим |
путь |
υ1...υiυj+1...υk . Его |
длина |
меньше, |
чем |
Π, что |
||
противоречит предположению. |
|
|
|
|
||||
2) |
(о |
минимальности |
подпути |
минимального |
пути). |
Пусть |
||
П = υ1υ2 ...υk |
υ1 ≠ υk - минимальный путь (маршрут) в орграфе D (в графе |
|||||||
G). Тогда для i и j таких, что 1 ≤ i < j ≤ k путь (маршрут) |
П0 =υiυi+1...υj |
|||||||
тоже является минимальным. |
|
П0 не |
является |
оптимальным, |
||||
Доказательство. Предположим, что |
||||||||
тогда |
П1 = υi...υj |
т.ч. он короче чем П0 . Если в |
П1 вошли вершины из |
(П − П0 ) , то этот путь не является простой цепью. Тогда исключив из него циклы, можно найти еще более короткий путь П не является минимальным. Пришли к противоречию.
Пусть D = (V,X) орграф υV - некоторая вершина υ V, V1 V . Обозначим D(υ) ={ω V | (υ,ω) X}- образ вершины υ;
D−1(υ) ={ω V | (ω,υ) X}- прообраз вершины υ;
D(V1) = |
U D(υ) - образ множества вершин V1 ; |
||
|
υ V1 |
|
|
D−1(V ) = |
U |
D−1(υ) прообраз множества вершин V1. |
|
1 |
|
|
υ V1
Для неориентированного графа образ и прообраз совпадают. Пусть G = (V,X) граф υV, V1 V .
Обозначим G(υ) ={ω V | {υ,ω} X}- образ вершины υ;
G(V1) = UG(υ) - образ множества вершин V1.
υ V1
Пусть D = (V,X) орграф с n≥2 вершинами и v,w (v≠w) – заданные вершины из V
Алгоритм поиска минимального пути из υ в ω в орграфе D
(алгоритм фронта волны). |
затем помечаем вершины |
|
1) Помечаем вершину |
υ индексом 0, |
|
образу вершины υ индексом 1. Обозначаем их FW1 (v). Полагаем k=1. |
||
2) Если FWk (υ) = |
или k=n-1, и |
одновременно ω FWk (υ) то |
вершина ω не достижима из υ. Работа алгоритма заканчивается.
В противном случае продолжаем:
3) Если ω FWk (υ) , то переходим к шагу 4.
В противном случае мы нашли минимальный путь из υ в ω и его
длина =k. Последовательность вершин
υω1ω2ω3...ωk −1ω
ωk −1 FWk −1(υ) ∩ D−1(ω)
ωk −2 FWk −2 (υ) ∩ D−1(ωk −1)
........................................
ω1 FW1(υ) ∩ D−1(ω2 )
есть этот минимальный путь. Работа завершается.
4) Помечаем индексом k+1 все непомеченные вершины, которые принадлежат образу множества вершин c индексом k. Множество вершин