Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

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




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

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

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

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

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

Рис. 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




Поделиться с друзьями:


Дата добавления: 2014-12-27; Просмотров: 2078; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2024) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.012 сек.