ГАДДАГ - GADDAG

А ГАДДАГ это структура данных представленный Стивеном Гордоном в 1994 году для использования при создании движений для Скраббл и другие игры по генерации слов, в которых для таких ходов требуются слова, которые «цепляются» за существующие слова. Это часто отличается от алгоритмов генерации ходов, использующих направленный ациклический граф слов (DAWG), например, используемый Maven. Обычно он в два раза быстрее традиционных алгоритмов DAWG, но занимает примерно в 5 раз больше места для стандартных словарей Scrabble.[1]

Quackle, программа Scrabble с открытым исходным кодом, использует GADDAG для генерации движений.[2]

Описание

Название GADDAG происходит от DAG для ориентированный ациклический граф, с префиксом собственного реверса.[1]

GADDAG - это специализация Trie, содержащий состояния и ветви к другим GADDAG. Он отличается хранением каждого перевернутого префикса каждого слова в словаре. Это означает, что каждое слово имеет столько же представлений, сколько букв; поскольку среднее слово в большинстве нормативных словарей Scrabble состоит из 5 букв, это делает GADDAG примерно в 5 раз больше, чем простая DAWG.

Определение

Для любого слова в словаре, образованного непустым префиксом Икс и суффикс у, GADDAG содержит прямой детерминированный путь для любой строки REV(Икс)+у, где + - оператор конкатенации.

Например, для слова "объяснять, "GADDAG будет содержать прямые пути к строкам

e + xplainxe + plainpxe + lainlpxe + ainalpxe + inialpxe + nnialpxe

Эта настройка позволяет искать слово по любой букве, которая в нем встречается.

Использование в генерации ходов

Любой алгоритм генерации ходов должен придерживаться трех типов ограничений:

  • Ограничения платы: можно строить, только «цепляясь» за существующие буквы на доске, и можно класть плитки только на пустые квадраты.
  • Ограничения стойки: на стойку можно класть только плитки с буквами.
  • Ограничение словаря: все слова, полученные в результате размещения плиток, присутствуют в словаре игры.

Алгоритмы на основе DAWG используют второе и третье ограничение: DAWG построена вокруг словаря и перемещается с использованием плиток в стойке. Однако он не может решить первое ограничение: предположим, что кто-то хочет `` зацепиться '' за букву. п в HARPY, и на доске есть 2 пробела перед буквой P, нужно искать в словаре все слова, содержащие буквы из стойки, где третья буква п. Это неэффективно при поиске в DAWG, так как многие поиски в дереве будут бесплодны.

Это решается хранением префиксов в GADDAG: путем обхода п ветви GADDAG, можно увидеть все слова, у которых есть п где-то в их составе и может «путешествовать вверх» приставка, образуя слово с плиткой в ​​стойке. Чтобы использовать пример из § Определение раздел, поиск п оказаться "pxe + lain". Буквы между п и + можно разместить над п на доске, а остальные под ней (если позволяет место на доске).

Смотрите также

использованная литература

  1. ^ а б Гордон, Стивен А. (1994). «Более быстрый алгоритм генерации движений Scrabble» (PDF). Программное обеспечение: практика и опыт. 24 (2): 219–232. Дои:10.1002 / spe.4380240205.
  2. ^ Джейсон Кац-Браун; Джон О'Лафлин. "Как Крякл играет в скрэббл". Получено 2018-07-02.