Главная страница Случайная страница КАТЕГОРИИ: АвтомобилиАстрономияБиологияГеографияДом и садДругие языкиДругоеИнформатикаИсторияКультураЛитератураЛогикаМатематикаМедицинаМеталлургияМеханикаОбразованиеОхрана трудаПедагогикаПолитикаПравоПсихологияРелигияРиторикаСоциологияСпортСтроительствоТехнологияТуризмФизикаФилософияФинансыХимияЧерчениеЭкологияЭкономикаЭлектроника |
Ребер смежности вершин
Занимаемое пространство памяти (space) E V2 V+E Инициализировать пустой объект (initialize empty) 1 V2 V Копировать (сору) Е V2 Е Уничтожить (destroy) 1 V Е Вставить ребра (insert edge) 1 1 1 Найти/удалить ребро (find/remove) E 1 V Вершина v изолирована? (is v isolated?) E V 1 Путь от вершины и к вершине v? (path from u to v?) E lg* V V2 V+E Во многих случаях удается модифицировать представление графа таким образом, что простые операции становятся более эффективными, при этом принимаем меры против того, чтобы стоимость других простых операций не увеличивалась. Например, вхождение в таблице, соответствующее строке destroy и столбцу матрицы смежности, есть следствие (артефакт) выбора схемы раcпределения типа вектор векторов для двухмерных матриц (см. раздел 3.7). Нетрудно уменьшить эти затраты, сделав их постоянными (см. упражнение 17.25). С другой стороны, если ребра графа представляют собой достаточно сложные структуры, для которых элементы матрицы служат указателями, то операция destroy над матрицей смежности потребует затрат, пропорциональных V2. В силу того, что некоторые операции используются в типовых приложениях особенно часто, подробно рассмотрим операции find edge (найти ребро) и remove edge (удалить ребро). В частности, операция find edge нужна нам для того, чтобы иметь возможность удалить или запретить включение параллельных ребер. Как следует из раздела 13.4, эти операции тривиальны, если мы пользуемся представлением графа в виде матрицы смежности — нам достаточно всего лишь проверить или установить значение элемента матрицы, который можно индексировать непосредственно. В то же время, как можно обеспечить эффективную реализацию этих операций в условиях представления графа в виде списка смежных вершин? В языке C++ можно воспользоваться библиотекой STL; здесь мы описываем базовые механизмы, чтобы получить представление о проблемах обеспечения эффективности. Один из подходов описан ниже, другой подход упоминается в упражнении 17.50. Оба подхода основаны на использовании реализаций таблицы символов. Например, если мы используем реализации динамической хэш-таблицы (см. раздел 14.5), оба подхода требуют памяти, пропорциональной Е, и позволяют выполнять и ту и другую операции за постоянное время (в среднем, с амортизацией расходов на реализацию). В частности, чтобы реализовать операцию find edge, когда мы используем списки смежных вершин, можно воспользоваться вспомогательной таблицей соответствия символов для ребер. Мы можем присвоить ребру v-w целочисленный ключ v*V+w и задействовать функцию тар из библиотеки STL или любую реализацию таблицы символов, описание которых приводится в части 4. (Для неориентированных графов можно присваивать одни и те же ключи ребрам v-w и w-v.) Мы можем вставить каждое ребро в таблицу символов, предварительно проверив, не было ли оно включено раньше. Мы можем остановить свой выбор либо на том, чтобы блокировать включение параллельных ребер (см. упражнение
|