Суффиксный массив — различия между версиями

Материал из Викиконспекты
Перейти к: навигация, поиск
(Определение)
(Определение)
Строка 2: Строка 2:
 
{{Определение
 
{{Определение
 
|definition=
 
|definition=
'''<tex>i</tex>—ым суффиксом''' строки <tex>s[1 .. n]</tex> называется подстрока <tex>s[i .. n]</tex>, <tex>i = 1 .. n</tex>.
+
'''<tex>i</tex>-ым суффиксом''' строки <tex>s[1 .. n]</tex> называется подстрока <tex>s[i .. n]</tex>, <tex>i = 1 .. n</tex>.
 
}}
 
}}
  
 
{{Определение
 
{{Определение
 
|definition=
 
|definition=
'''Cуффиксным массивом''' строки <tex>s[1 .. n]</tex> называется массив <tex>suf</tex> целых чисел от <tex>1</tex> до <tex>n</tex>, такой, что суффикс под номером <tex>suf[i]</tex> — <tex>i</tex>—й в лексикографическом порядке.}}
+
'''Cуффиксным массивом''' строки <tex>s[1 .. n]</tex> называется массив <tex>suf</tex> целых чисел от <tex>1</tex> до <tex>n</tex>, такой, что суффикс под номером <tex>suf[i]</tex> — <tex>i</tex>в лексикографическом порядке.}}
  
 
== Пример ==
 
== Пример ==

Версия 22:26, 21 июня 2012

Определение

Определение:
[math]i[/math]-ым суффиксом строки [math]s[1 .. n][/math] называется подстрока [math]s[i .. n][/math], [math]i = 1 .. n[/math].


Определение:
Cуффиксным массивом строки [math]s[1 .. n][/math] называется массив [math]suf[/math] целых чисел от [math]1[/math] до [math]n[/math], такой, что суффикс под номером [math]suf[i][/math][math]i[/math]-й в лексикографическом порядке.


Пример

[math]s = abacaba[/math]. Суффиксы [math]s[/math] в лексикографическом порядке:
1) [math]a[/math]
2) [math]aba[/math]
3) [math]abacaba[/math]
4) [math]acaba[/math]
5) [math]ba[/math]
6) [math]bacaba[/math]
7) [math]caba[/math]
Значит суффиксный массив для строки [math]s[/math] равен [math](7, 5, 1, 3, 6, 2, 4)[/math]

Применения

  • Позволяет найти все вхождения образца [math]p[/math] в строку [math]s[/math] за время [math]O(|p| + \log(|s|))[/math]
  • Позволяет вычислить [math]lcp[/math] (longest common prefix) для всех соседних в лексикографическом порядке суффиксов строки [math]s[/math] за [math]O(|s|)[/math], то есть построить массив [math]lcp[1 .. |s| - 1][/math], где [math]lcp[i][/math] — длина наибольшего общего префикса суффиксов [math]s[suf[i] .. |s|][/math] и [math]s[suf[i + 1] .. |s|][/math].

Литература

  • Гасфилд Д. Строки, деревья и последовательности в алгоритмах: Информатика и вычислительная биология. — 2-е изд.

См. также