Изменения

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

Турбо-алгоритм Бойера-Мура

50 байт добавлено, 20:10, 3 мая 2016
Описание алгоритма
* Если текущем шаге у нас подстрока совпала с шаблоном <tex>x</tex>, то <tex>shift = bmGs[0]</tex> (<tex>bmGs[0]</tex> равен периоду шаблона <tex>x</tex>), <tex>|u| = m - shift</tex>.
* Иначе возможны два случая:
** Если сдвиг хорошего суффикса не меньше турбо-сдвига и сдвига плохого символа, тогда <tex>shift = bmGs[j+1]</tex>, <tex>|u| = min(m - shift, |v|)</tex> (, где <tex>v</tex> {{---}} текущая подстрока).** В противном случае, <tex>|u| = 0)</tex>, <tex>shift = max(turboShift, bCShift)</tex>(, где <tex>turboShift</tex> {{---}} длина турбо-сдвига, <tex>bCShift</tex> {{---}} длина сдвига плохого символа), если . Если турбо-сдвиг меньше сдвига плохого символа, то <tex>shift</tex> должен быть не больше <tex>|u_0| + 1</tex> (, где <tex>u_0</tex> {{---}} сегмент текста, рассматриваемый на прошлом шаге).
==Псевдокод==
Анонимный участник

Навигация