Сжатое суффиксное дерево — различия между версиями
(→Определение) |
(→Существование сжатого суффиксного дерева) |
||
Строка 4: | Строка 4: | ||
'''Суффиксное дерево''' (сжатое суффиксное дерево) <tex>T</tex> для строки <tex>s</tex> (где <tex>|s| = n</tex>) {{---}} ориентированное дерево с <tex>n</tex> листьями, каждая внутренняя вершина которого имеет не меньше двух детей, а каждое ребро помечено непустой подстрокой строки <tex>s</tex> и символом, с которого начинается эта подстрока. При этом два ребра, выходящие из одной вершины, не могут иметь одинаковых символьных пометок. Такое дерево содержит все суффиксы строки <tex>s</tex>: для каждого листа <tex>i</tex> конкатенация подстрок на ребрах пути от корня к этому листу составляет суффикс, который начинается в позиции <tex>i</tex>, то есть <tex>s[i..n]</tex>. Иными словами, каждый суффикс строки <tex>s</tex> заканчивается точно в листе и нигде кроме листа, как и в суффиксном боре. | '''Суффиксное дерево''' (сжатое суффиксное дерево) <tex>T</tex> для строки <tex>s</tex> (где <tex>|s| = n</tex>) {{---}} ориентированное дерево с <tex>n</tex> листьями, каждая внутренняя вершина которого имеет не меньше двух детей, а каждое ребро помечено непустой подстрокой строки <tex>s</tex> и символом, с которого начинается эта подстрока. При этом два ребра, выходящие из одной вершины, не могут иметь одинаковых символьных пометок. Такое дерево содержит все суффиксы строки <tex>s</tex>: для каждого листа <tex>i</tex> конкатенация подстрок на ребрах пути от корня к этому листу составляет суффикс, который начинается в позиции <tex>i</tex>, то есть <tex>s[i..n]</tex>. Иными словами, каждый суффикс строки <tex>s</tex> заканчивается точно в листе и нигде кроме листа, как и в суффиксном боре. | ||
− | == | + | ==Защитный символ== |
[[Файл:Suffix_tree_3.png|thumb|right|Суффиксное дерево для строки <tex>xabxa</tex> с защитным символом]] | [[Файл:Suffix_tree_3.png|thumb|right|Суффиксное дерево для строки <tex>xabxa</tex> с защитным символом]] | ||
− | Определение суффиксного дерева не гарантирует, что такое дерево существует для любой строки <tex>s</tex>. Если один суффикс совпадает с префиксом другого | + | Определение суффиксного дерева не гарантирует, что такое дерево существует для любой строки <tex>s</tex>. Если один суффикс строки совпадает с префиксом другого, то построить суффиксное дерево, удовлетворяющее данному выше определению, невозможно. Например, для строки <tex>xabxa</tex> суффикс <tex>xa</tex> является префиксом суффикса <tex>xabxa.</tex> Во избежание этого в конце строки <tex>s</tex> добавляется символ, не входящий в исходный алфавит. Такой символ называется '''''защитным'''''. Как правило, это <tex>\$</tex>. Любой суффикс строки с защитным символом заканчивается в листе, т.к. он не встречается в строке нигде, кроме позиции последнего символа. |
Далее <tex>n</tex> - длина строки <tex>s</tex> с защитным символом. | Далее <tex>n</tex> - длина строки <tex>s</tex> с защитным символом. |
Версия 14:01, 7 мая 2012
Суффиксный бор — удобная структура для поиска подстроки в строке, но занимающая много места в памяти. Рассмотрим все такие пути от до в суффиксном боре, в которых каждая вершина имеет только одного сына. Такие пути можно сжать до одного ребра , пометив его всеми встречающимися на пути символами. Получившееся дерево носит название сжатое суффиксное дерево.
Содержание
Определение
Суффиксное дерево (сжатое суффиксное дерево)
для строки (где ) — ориентированное дерево с листьями, каждая внутренняя вершина которого имеет не меньше двух детей, а каждое ребро помечено непустой подстрокой строки и символом, с которого начинается эта подстрока. При этом два ребра, выходящие из одной вершины, не могут иметь одинаковых символьных пометок. Такое дерево содержит все суффиксы строки : для каждого листа конкатенация подстрок на ребрах пути от корня к этому листу составляет суффикс, который начинается в позиции , то есть . Иными словами, каждый суффикс строки заканчивается точно в листе и нигде кроме листа, как и в суффиксном боре.Защитный символ
Определение суффиксного дерева не гарантирует, что такое дерево существует для любой строки
. Если один суффикс строки совпадает с префиксом другого, то построить суффиксное дерево, удовлетворяющее данному выше определению, невозможно. Например, для строки суффикс является префиксом суффикса Во избежание этого в конце строки добавляется символ, не входящий в исходный алфавит. Такой символ называется защитным. Как правило, это . Любой суффикс строки с защитным символом заканчивается в листе, т.к. он не встречается в строке нигде, кроме позиции последнего символа.Далее
- длина строки с защитным символом.Хранение суффиксного дерева
Как уже было отмечено выше, каждое ребро дерева помечается подстрокой исходной строки
. Можно для каждого ребра хранить не саму подстроку, а индексы начала и конца подстроки в исходной строке — . Итак, с каждым ребром дерева ассоциируются две инцидентные ей вершины, символ, с которого начинается подстрока на ребре и два числа . Представим дерево как массив , где — количество вершин в дереве. Каждая ячейка массива содержит информацию о том, в какую вершину ведет ое ребро по ому символу и индексы подстроки на ребре.Количество вершин
В сжатом суффиксном дереве содержится
листьев, т.к. каждый суффикс строки заканчивается в листе. Рассмотрим теперь количество внутренних вершин такого дерева.Лемма: |
Количество внутренних вершин дерева, каждая из которых имеет не менее двух детей, меньше количества листьев. |
Доказательство: |
Докажем лемму индукцией по количеству листьев .База При в дереве одна внутренняя вершина - верно.Переход Рассмотрим все вершины в дереве для строки длины , у которых хотя бы один из детей - лист.Если среди них есть вершина, у которой более двух детей, отрежем от нее лист. Получим дерево с Иначе среди этих вершин есть вершина, у которой оба ребенка - листья. Отрежем оба этих листа, получим дерево с листьями, удовлетворяющее условию леммы по индукционному предположению, причем в нем количество внутренних вершин равно количеству внутренних вершин в исходном дереве. Тогда у полученного дерева менее внутренних вершин, значит в исходном дереве количество внутренних вершин так же меньше количества листьев. листьями, удовлетворяющее условию леммы, количество внутренних вершин которого на меньше количества внутренних вершин в исходном дереве. Тогда, по индукционному предположению, у полученного дерева менее внутренних вершин, значит в исходном дереве количество внутренних вершин меньше . |
Занимаемая память
Очевидно, суффиксное дерево в виде массива занимает
памяти. Так как любое суффиксное дерево удовлетворяет условиям леммы, и все его внутренние вершины, по определению, имеют не менее двух детей, то количество внутренних вершин в нем меньше количества листьев, равного , поэтому для его хранения требуется памяти.Построение суффиксного дерева
Рассмотрим наивный алгоритм построения суффиксного дерева:
forto do //для каждого символа строки insert( ) //добавляем суффикс, начинающийся с него
insert(l,r) //процедура вставки//инициализируем текущую вершину корнем while ( ) if //если мы не можем пойти из вершины по символу create_vertex( ) //создаем новую вершину else for to //для каждого символа на ребре из текущей вершины if //нашли не совпадающий символ разбить ребро break if ребро не разбивали //переходим по ребру //двигаемся по суффиксу на длину подстроки, записанной на ребре
Этот алгоритм работает за время алгоритм Укконена, позволяющий построить дерево за время .
, однако существуетИспользование
Суффиксное дерево позволяет за линейное время найти:
- Количество различных подстрок данной строки
- Наибольшую общую подстроку двух строк
- Суффиксный массив и массив (longest common prefix) исходной строки
Источники
- Дэн Гасфилд — Строки, деревья и последовательности в алгоритмах: Информатика и вычислительная биология — СПб.: Невский Диалект; БХВ-Петербург, 2003. — 654 с: ил.