Изменения

Перейти к: навигация, поиск

Алгоритм Кнута-Морриса-Пратта

6 байт добавлено, 23:13, 30 мая 2014
Описание алгоритма
Дана цепочка <tex>T</tex> и образец <tex>P</tex>. Требуется найти все позиции, начиная с которых <tex>P</tex> входит в <tex>T</tex>.
<br>
Построим строку <tex>S = P\#T</tex>, где <tex>\#</tex> — любой символ, не входящий в алфавит <tex>P</tex> и <tex>T</tex>. Посчитаем на ней значение [[Префикс-функция|префикс-функции]]<tex> p </tex>. Благодаря разделительному символу <tex>\#</tex>, выполняется <tex>\forall i: \pip[i] \leqslant |P|</tex>. Заметим, что по определению [[Префикс-функция|префикс-функции]] при <tex>i > |P|</tex> и <tex>\pip[i] = |P|</tex> подстроки длины <tex>P</tex>, начинающиеся с позиций <tex>0</tex> и <tex>i - |P| + 1</tex>, совпадают. Соберем все такие позиции <tex>i - |P| + 1</tex> строки <tex>S</tex>, вычтем из каждой позиции <tex>|P| + 1</tex>, это и будет ответ. Другими словами, если в какой-то позиции <tex>i</tex> выполняется условие <tex>\pip[i]=|P|</tex>, то в этой позиции начинается очередное вхождение образца в цепочку.<br> 
[[Файл:kmp_pict2.png|640px]]

Навигация