Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:

disc_lekcii

.pdf
Скачиваний:
10
Добавлен:
25.04.2014
Размер:
2.56 Mб
Скачать

Теорема || Из всякого незамкнутого маршрута (пути) можно выделить простую

цепь с теми же начальной и конечной вершинами. Доказательство || аналогично предыдущему. Определение. Композицией путей (маршрутов)

Π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 длины k1. Столбец под номером 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}- образ вершины υ;

D1(υ) ={ω V | (ω,υ) X}- прообраз вершины υ;

D(V1) =

U D(υ) - образ множества вершин V1 ;

 

υ V1

 

D1(V ) =

U

D1(υ) прообраз множества вершин V1.

1

 

 

υ V1

Для неориентированного графа образ и прообраз совпадают. Пусть G = (V,X) граф υV, V1 V .

Обозначим G(υ) ={ω V | {υ,ω} X}- образ вершины υ;

G(V1) = UG(υ) - образ множества вершин V1.

υ V1

Пусть D = (V,X) орграф с n2 вершинами и v,w (vw) – заданные вершины из 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(υ) D1(ω)

ωk 2 FWk 2 (υ) D1(ωk 1)

........................................

ω1 FW1(υ) D1(ω2 )

есть этот минимальный путь. Работа завершается.

4) Помечаем индексом k+1 все непомеченные вершины, которые принадлежат образу множества вершин c индексом k. Множество вершин

Соседние файлы в предмете Дискретная математика