Матричные представления графов
Информация о структуре графа может быть задана матрицей смежности. Матрицей смежности графа 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.
Рис. 4.13: а) ориентированный граф и его матрица инцидентности, б) неориентированный граф и его матрица инцидентности
Рис. 4.14. Матрицы смежности для графов на рис. 4.13 Представление графов в ЭВМ Очевидно, что наиболее понятный и полезный для человека способ представления графа – изображение графа на плоскости в виде точек и соединяющих их линий – будет совершенно бесполезным, если решать задачи, связанные с графами, с помощью ЭВМ. Выбор соответствующей структуры данных для представления графов имеет принципиальное влияние на эффективность алгоритмов. Рассмотрим различные способы представления графов. В теории графов классическим способом представления графа служит матрица инцидентности. Это матрица В с n строками, соответствующими вершинам, и т столбцами, соответствующими ребрам. С алгоритмической точки зрения матрица инцидентности является, вероятно, самым худшим способом представления графа, который только можно себе представить. Во-первых, он требует п´т ячеек памяти, причем большинство этих ячеек вообще занято нулями. Неудобен также доступ к информации. Ответ наэлементарные вопросы типа «существует ли дуга (xi, xj)?», «к каким вершинам ведут ребра из хi ?»требует в худшем случае перебора всех столбцов матрицы, а следовательно, т шагов. Лучшим способомпредставления графа является матрица смежности,определяемая как матрица А =(аij)размера n
Основным преимуществом матрицы смежности является тот факт, что за один шаг можно получить ответ на вопрос «существует ли ребро из хi в xj?». Недостатком жеявляется тот факт, что независимо от числа ребер объем занятой памяти составляет n2. На практике этонеудобство можно иногда уменьшить, храня целую строку (столбец) матрицы в одном машинном слове – это возможно для малых n. Более экономным в отношении памяти (особенно в случае неплотных графов, когда т гораздо меньше n2)является метод представления графа с помощью списка пар, соответствующих его ребрам. Пара (xi, xj) соответствует дуге (xi, xj),если граф ориентированный, и ребру (xi, xj) в случае неориентированного графа (рис. 4.15). Очевидно, что объем памяти в этом случае составляет 2 m. Неудобством является большое число шагов – порядка т в худшем случае, – необходимое для получения множества вершин, к которым ведут ребра из данной вершины. Рис. 4.15. Списки ребер, соответствующие графам на рис 4.13
Ситуацию можно значительно улучшить, упорядочив множество пар лексикографически и применяя двоичный поиск, но лучшимрешением во многих случаях оказывается структура данных, которую называют списками инцидентности. Она содержит для каждой вершины Отметим, что для неориентированных графов каждое, ребро (xj, xi) представлено дважды: через вершину xi в списке ЗАПИСЬ[xj] и через вершину xj в списке ЗАПИСЬ[xi]. Во многих алгоритмах структура графа динамически модифицируется добавлением и удалением ребер. Каждый элемент списка может содержать указатель не только к следующему элементу, но и к предыдущему. Аналогичным способом определяем для каждой вершины xi неориентированного графа список ПРЕДШ[xi], содержащий вершины из множества (xj: xi – xj).
Число ячеек памяти, необходимое для представления графа с помощью списков инцидентности, будет, очевидно, иметь порядок т+n. На рис. 4.16 представлены списки инцидентности, соответствующие графам на рис. 4.13.
Рис. 4.16. Списки инцидентности ЗАПИСЬ, соответствующие графам на рис. 4.13 Операции над графами
Рассмотрим операции над графами. I. Бинарные операции. 1. Объединение графов. Рассмотрим графы 2. Пересечение графов. Пересечение графов 3. Кольцевой суммой Замечание. Объединение, пересечение и другие операции над ориентированными графами определяются точно также, как и в случае неориентированных графов. Пример. Для графов G1 =({ x 1, x 2, x 3}, {(x 1, x 2), (x 2, x 3)}) и G2 =({ x 1, x 2, x 4}, {(x 1, x 2), (x 4, x 1)}) (рис. 4.17) найдем
4. Соединением графов G1 + G2 называется граф Пример. Для графов G1 и G2, показанных на рис. 4.18 а, соединением G1+G2 является граф, представленным на рис. 4.18 б. 5. Произведением
Пример. На рис. 4.19 изображено произведение ![]()
II. Унарные операции. 1. Удаление вершины. При удалении вершины из графа удаляются и все инцидентные ей ребра (дуги).Пусть
До удаления вершины x После удаления вершины x
2. Удаление ребра (дуги). Пусть ![]() ![]() ![]() ![]() ![]()
До удаления ребра v. Послеудаления ребра v При удалении ребра (дуги) его концевые вершины не удаляются. Операцией, являющейся обратной к удалению ребра, является добавление ребра. 3. Слияние или отождествление вершин. Говорят, что вершины 4. Стягивание ребра (дуги). Эта операция означает удаление ребра и отождествление его концевых вершин. Граф G 1 называется стягиваемым к графу G 2, если граф G 2 может быть получен из G 1 в результате некоторой последовательности стягиваний ребер.
5. Подразбиение ребра. Пусть
z
yy До внесения вершины z После внесения вершины z Граф Пусть G’ =(X’, V’) является подграфом графа G =(X, V). Подграф G’’ =(X, V \ V’) графа G называется дополнением графа G’ в графе G.
Воспользуйтесь поиском по сайту: ![]() ©2015 - 2025 megalektsii.ru Все авторские права принадлежат авторам лекционных материалов. Обратная связь с нами...
|