Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Пособие по дискретной математике (часть 2).doc
Скачиваний:
81
Добавлен:
29.10.2018
Размер:
2.38 Mб
Скачать

4.3. Матричные представления графов

Информация о структуре графа может быть задана матрицей смежности. Матрицей смежности графа G=(X,V), |X|=n называется квадратная матрица , элементы которой определяются следующим образом:

Замечание. Матрица смежности неориентированного графа симметрична. В случае кратных ребер aij есть количество ребер, соединяющих вершины xi и xj. Для орграфа аij определяется как количество дуг, направленных от вершины xi к вершине xj.

Теорема 4.3.1. Графы изоморфны тогда и только тогда, когда их матрицы смежности получаются друг из друга одновременными перестановками строк и столбцов (т.е. одновременно с перестановкой i-й и j-й строк переставляются i-й и j-й столбцы).

Согласно этой теореме по матрице смежности граф восстанавливается однозначно с точностью до изоморфизма.

Матрицей инцидентности графа G=(X,V), |Х|=п ,|V|=m называется матрица , элементы которой определяются следующим образом:

е сли G – ориентированный граф, то

если G - неориентированный граф, то

Замечание. Для ориентированного графа петлю, т. е. дугу вида (хi, хi) удобно представлять иным значением в строке хi, например, 2.

Пример. Матричные представления графов проиллюстрированы на рис. 4.13, 4.14.

(1,2)

(1,3)

(3,2)

(3,4)

(5,4)

(5,6)

(6,5)

1

1

1

0

0

0

0

0

2

-1

0

-1

0

0

0

0

В=

3

0

-1

1

1

0

0

0

4

0

0

0

-1

-1

0

0

5

0

0

0

0

1

1

-1

6

0

0

0

0

0

-1

1

(1,2)

(1,3)

(1,5)

(2,3)

(2,5)

(3,4)

(4,5)

(4,6)

(5,6)

1

1

1

1

0

0

0

0

0

0

2

1

0

0

1

1

0

0

0

0

В=

3

0

1

0

1

0

1

0

0

0

4

0

0

0

0

0

1

1

1

0

5

0

0

1

0

1

0

1

0

1

6

0

0

0

0

0

0

0

1

1

Рис. 4.13.

а) ориентированный граф и его матрица инцидентности,

б) неориентированный граф и его матрица инцидентности

Рис. 4.14. Матрицы смежности для графов на рис. 4.13

4.4. Представление графов в ЭВМ

Очевидно, что наиболее понятный и полезный для человека способ представления графа – изображение графа на плоскости в виде точек и соединяющих их линий – будет совершенно бесполезным, если решать задачи, связанные с графами, с помощью ЭВМ. Выбор соответствующей структуры данных для представления графов имеет принципиальное влияние на эффективность алгоритмов. Рассмотрим различные способы представления графов.

В теории графов классическим способом представления графа служит матрица инцидентности. Это матрица В с n строками, соответствующими вершинам, и т столбцами, соответствующими ребрам. С алгоритмической точки зрения матрица инцидентности является, вероятно, самым худшим способом представления графа, который только можно себе представить. Во-первых, он требует пт ячеек памяти, причем большинство этих ячеек вообще занято нулями. Неудобен также доступ к информации. Ответ на элементарные вопросы типа «существует ли дуга (xi, xj) ?», «к каким вершинам ведут ребра из хi требует в худшем случае перебора всех столбцов матрицы, а следовательно, т шагов.

Лучшим способом представления графа является матрица смежности, определяемая как матрица А=[аij] размера nn. Здесь мы подразумеваем, что ребро (xi, xj) неориентированного графа идет как от xi к xj, так и от xj к хi, так что матрица смежности такого графа всегда является симметричной. Это проиллюстрировано на рис. 4.14б.

Основным преимуществом матрицы смежности является тот факт, что за один шаг можно получить ответ на вопрос «существует ли ребро из хi в xj. Недостатком же является тот факт, что независимо от числа ребер объем занятой памяти составляет n2. На практике это неудобство можно иногда уменьшить, храня целую строку (столбец) матрицы в одном машинном слове – это возможно для малых n.

Более экономным в отношении памяти (особенно в случае неплотных графов, когда т гораздо меньше n2) является метод представления графа с помощью списка пар, соответствующих его ребрам. Пара (xi, xj) соответствует дуге (xi, xj), если граф ориентированный, и ребру (xi, xj) в случае неориентированного графа (рис. 4.15). Очевидно, что объем памяти в этом случае составляет 2m. Неудобством является большое число шагов – порядка т в худшем случае, – необходимое для получения множества вершин, к которым ведут ребра из данной вершины.

Рис. 4.15. Списки ребер, соответствующие графам на рис 4.13

Ситуацию можно значительно улучшить, упорядочив множество пар лексикографически и применяя двоичный поиск, но лучшим решением во многих случаях оказывается структура данных, которую называют списками инцидентности. Она содержит для каждой вершины список вершин xj, таких что (или xixj в случае неориентированного графа). Точнее, каждый элемент такого списка является записью r, содержащей вершину r.строка и указатель r.след на следующую запись в списке (r.след=nil для последней записи в списке). Начало каждого списка хранится в таблице НАЧАЛО; точнее, НАЧАЛО[xi] является указателем на начало списка, содержащего вершины из множества (xj: ) ((xj: xixj) для неориентированного графа). Весь такой список обычно неформально будем обозначать ЗАПИСЬ[xi], а цикл, выполняющий определенную операцию для каждого элемента xj из этого списка в произвольной, но четко установленной последовательности, соответствующей очередности элементов в списке, будем записывать «fоr xjЗАПИСЬ[xi] do ...».

Отметим, что для неориентированных графов каждое, ребро (xj, xi) представлено дважды: через вершину xi в списке ЗАПИСЬ[xj] и через вершину xj в списке ЗАПИСЬ[xi]. Во многих алгоритмах структура графа динамически модифицируется добавлением и удалением ребер. Каждый элемент списка может содержать указатель не только к следующему элементу, но и к предыдущему. Аналогичным способом определяем для каждой вершины xi неориентированного графа список ПРЕДШ[xi], содержащий вершины из множества (xj: xixj).

Число ячеек памяти, необходимое для представления графа с помощью списков инцидентности, будет, очевидно, иметь порядок т+n. На рис. 4.16 представлены списки инцидентности, соответствующие графам на рис. 4.13.

Рис. 4.16. Списки инцидентности ЗАПИСЬ,

соответствующие графам на рис. 4.13