Изменения

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

Z-функция

42 байта добавлено, 01:51, 16 апреля 2012
Алгоритм поиска
Есть два случая: <tex>i > right</tex> и <tex>i \leq right</tex>.
===<br>1) <tex>i > right===</tex>:<br>просто Просто пробегаемся по строке <tex>S</tex> и сравниваем символы на позициях <tex>S[i+j]</tex> и <tex>S[j]</tex>.
Пусть <tex>j</tex> первая позиция в строке <tex>S</tex> для которой не выполняется равенство <tex>S[i+j] == S[j]</tex>, тогда <tex>j</tex> это и Z-функция для позиции <tex>i</tex>. Тогда <tex>left = i, right = i + j - 1</tex>.
===<br>2) <tex>i \le right< right + 1===/tex>:<br>сравним Сравним <tex>Z[i - left] + i</tex> и <tex>right</tex>. Если <tex>right</tex> меньше, то надо просто пробежаться по строке начиная с позиции <tex>right</tex> и вычислить значение <tex>Z[i]</tex>.
Иначе мы уже знаем значение <tex>Z[i]</tex>, так как оно равно значению <tex>Z[i - left]</tex>.
<br>[[Файл:z-ffunc.png]]
===Время работы алгоритма===
Анонимный участник

Навигация