Наивный алгоритм поиска подстроки в строке — различия между версиями
(Новая страница: «Подстрока») |
|||
Строка 1: | Строка 1: | ||
− | + | ==Постановка задачи== | |
+ | Имеются строки <tex>T[1 .. n]</tex> и <tex>P[1 .. m]</tex> такие, что <tex>n</tex> <tex>\ge</tex> <tex>m</tex> и элементы этих строк <tex>-</tex> символы из конечного алфавита <tex> \sum </tex>. Говорят, что строка <tex>P</tex> встречается в строке <tex>T</tex> со сдвигом <tex>s</tex>, если <tex> 0 \le s \le n-m</tex> и <tex>T[s + 1 .. s + m]</tex> = <tex>P[1..m]</tex>. Если строка <tex>P</tex> встречается в строке <tex>T</tex>, то <tex>P</tex> является подстрокой <tex>T</tex>. Требуется проверить, является ли строка <tex>P</tex> подстрокой <tex>T</tex>. | ||
+ | |||
+ | ==Алгоритм== | ||
+ | В наивном алгоритме поиск всех допустимых сдвигов производится с помощью цикла, в котором проверяется условие <tex>T[s + 1 .. s + m]</tex> = <tex>P[1..m]</tex> для каждого из <tex> n-m+1</tex> возможных значений <tex>s</tex>. | ||
+ | |||
+ | ==Псевдокод== | ||
+ | |||
+ | '''Naive_String_Matcher''' (<tex>T,P</tex>) | ||
+ | <tex>n \leftarrow length[T]</tex> | ||
+ | <tex>m \leftarrow length[P]</tex> | ||
+ | '''for''' <tex>s \leftarrow 0</tex> to <tex>n - m</tex> | ||
+ | '''do if''' <tex>T[s + 1 .. s + m]</tex> = <tex>P[1..m]</tex> | ||
+ | '''then''' print() | ||
+ | |||
+ | |||
+ | == Литература == | ||
+ | * ''Кормен Т., Лейзерсон Ч., Ривест Р.'' Алгоритмы: построение и анализ.[http://wmate.ru/ebooks/?dl=380&mirror=1] — 2-е изд. — М.: Издательский дом «Вильямс», 2007. — С. 1296. |
Версия 07:57, 1 марта 2011
Содержание
Постановка задачи
Имеются строки
и такие, что и элементы этих строк символы из конечного алфавита . Говорят, что строка встречается в строке со сдвигом , если и = . Если строка встречается в строке , то является подстрокой . Требуется проверить, является ли строка подстрокой .Алгоритм
В наивном алгоритме поиск всех допустимых сдвигов производится с помощью цикла, в котором проверяется условие
= для каждого из возможных значений .Псевдокод
Naive_String_Matcher () for to do if = then print()
Литература
- Кормен Т., Лейзерсон Ч., Ривест Р. Алгоритмы: построение и анализ.[1] — 2-е изд. — М.: Издательский дом «Вильямс», 2007. — С. 1296.