Алгоритм Фараха — различия между версиями
Slavian (обсуждение | вклад) (→шаг 1: построение нечетного дерева) |
Slavian (обсуждение | вклад) (→описание алгоритма) |
||
Строка 8: | Строка 8: | ||
Мы опишем алгоритм Фарача в виде пяти выполняемых шагов. Используем в качестве примера строку <tex>s = 121112212221</tex>, определенную на алфавите <tex>А = {1, 2} </tex> (в этом примере N = 12). | Мы опишем алгоритм Фарача в виде пяти выполняемых шагов. Используем в качестве примера строку <tex>s = 121112212221</tex>, определенную на алфавите <tex>А = {1, 2} </tex> (в этом примере N = 12). | ||
+ | == шаг 0: суффиксное дерево для сжатой строки== | ||
== шаг 1: построение нечетного дерева == | == шаг 1: построение нечетного дерева == | ||
Строка 18: | Строка 19: | ||
== шаг 4: построение LCP-дерева == | == шаг 4: построение LCP-дерева == | ||
== шаг 5: построение суффиксного дерева по LCP и слитому == | == шаг 5: построение суффиксного дерева по LCP и слитому == | ||
− | |||
= аспекты реализации = | = аспекты реализации = |
Версия 13:43, 13 мая 2014
Алгоритм Фарача — алгоритм построения суффиксного дерева для заданной строки , который выполняется за время , при этом даже не требуется выполнения условия конечности алфавита. Такая эффективность достигается за счет того, что строковые последовательности определяются на индексированном алфавите или, что эквивалентно, на целочисленном алфавите , при этом накладывается дополнительное условие, что . Такие алфавиты часто встречаются на практике.
описание алгоритма
Основная идея алгоритма, заключается в том что мы уменьшаем размер исходной строки. Для этого мы разбиваем символы сходной строки на пару и пронумеровываем их, а из полученных номеров составляем новую строку, которая уже в 2 раза короче.
Мы опишем алгоритм Фарача в виде пяти выполняемых шагов. Используем в качестве примера строку
, определенную на алфавите (в этом примере N = 12).шаг 0: суффиксное дерево для сжатой строки
шаг 1: построение нечетного дерева
Определение: |
Нечетное дерево | является деревом суффиксов для строки , узлы-листья которого ограничены нечетными позициями строки .