Z-функция — различия между версиями
(Новая страница: «==Определение== Z-функция от строки <tex>S</tex> и позиции <tex>x</tex>, это длина максимального префик…») |
(→Алгоритм поиска) |
||
| Строка 6: | Строка 6: | ||
*'''Описание алгоритма''' | *'''Описание алгоритма''' | ||
*'''Код алгоритма''' | *'''Код алгоритма''' | ||
| − | int[] z(String p) { | + | int[] z(String p) { |
| − | + | int[] ans = new int[p.length()]; | |
| − | + | ans[0] = 0; | |
| − | + | int n = p.length(); | |
| − | + | int left = 0; | |
| − | + | int right = 0; | |
| − | + | for (int i = 1; i < n; i++) { | |
| − | + | if (i > right) { | |
| − | + | int j = 0; | |
| − | + | while (i + j < n && p.charAt(i+j) == p.charAt(j)) { | |
| − | + | j++; | |
| − | + | } | |
| − | + | ans[i] = j; | |
| − | + | left = i; | |
| − | + | right = i + j - 1; | |
| − | + | } else { | |
| − | + | if (ans[i - left] < right - i + 1) { | |
| − | + | ans[i] = ans[i - left]; | |
| − | + | } else { | |
| − | + | int j = 1; | |
| − | + | while (j + right < n && p.charAt(j+right-i) == p.charAt(right + j)) { | |
| − | + | j++; | |
| − | + | } | |
| − | + | ans[i] = right + j - i; | |
| − | + | left = i; | |
| − | + | right = right + j - 1; | |
| − | + | } | |
| − | + | } | |
| − | + | } | |
| − | + | return ans; | |
| − | } | + | } |
Версия 15:44, 7 мая 2011
Определение
Z-функция от строки и позиции , это длина максимального префикса подстроки, начинающейся с позиции в строке , который одновременно является и префиксом всей строки .
Алгоритм поиска
- Задача
Дана строка . Необходимо построить массив , такой что является префикс функцией данной строки с позиции
- Описание алгоритма
- Код алгоритма
int[] z(String p) {
int[] ans = new int[p.length()];
ans[0] = 0;
int n = p.length();
int left = 0;
int right = 0;
for (int i = 1; i < n; i++) {
if (i > right) {
int j = 0;
while (i + j < n && p.charAt(i+j) == p.charAt(j)) {
j++;
}
ans[i] = j;
left = i;
right = i + j - 1;
} else {
if (ans[i - left] < right - i + 1) {
ans[i] = ans[i - left];
} else {
int j = 1;
while (j + right < n && p.charAt(j+right-i) == p.charAt(right + j)) {
j++;
}
ans[i] = right + j - i;
left = i;
right = right + j - 1;
}
}
}
return ans;
}