Направленный ациклический граф | это... Что такое Направленный ациклический граф? (original) (raw)

Directed acyclic graph.png

Направленный ациклический граф или ориентированный ациклический граф (англ. directed acyclic graph, сокращённо англ. DAG) — случай направленного графа, в котором отсутствуют направленные циклы, то есть пути, начинающиеся и кончающиеся в одной и той же вершине. Направленный ациклический граф является обобщением дерева (точнее, их объединения — леса).

Применения

Оптимизация префиксного дерева

DAWG (англ. directed acyclic word graph) — компактная форма хранения префиксного дерева, списка слов, оптимизированная для выяснения, входит ли некое слово в данный список или нет. Сам список получить несложно рекурсивным обходом дерева. С точки зрения программы, осуществляющей обход или поиск, DAWG ничем не отличается от дерева, просто одинаковые поддеревья хранятся в единственном экземпляре.

Сам способ преобразования очевиден: поиск одинаковых поддеревьев и переподключение ссылок на единственный экземпляр. На самом деле помимо буквы в вершинах хранится флажок, указывающий, является ли данная буква последней. Так что для списков неповторяющихся слов преобразование в DAWG и обратно происходит без потерь (с точностью до порядка слов).

Question book-4.svg В этой статье не хватает ссылок на источники информации. Информация должна быть проверяема, иначе она может быть поставлена под сомнение и удалена.Вы можете отредактировать эту статью, добавив ссылки на авторитетные источники.Эта отметка установлена 14 мая 2011.
Есть более полная статья
Просмотр этого шаблона Структуры данных (список)
Типы КоллекцияКонтейнер
Массивы Ассоциативный массив • Multimap • МножествоМультимножествоХеш-таблица
Списки Связный списокОчередь (Кольцевой буферДвусвязная) • СтекСписок с пропусками
Деревья B-деревоДвоичное дерево поискаКуча
Графы Ориентированный графНаправленный ациклический графБинарная диаграмма решенийГиперграф