Z-функция — различия между версиями

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

Версия 15:44, 7 мая 2011

Определение

Z-функция от строки [math]S[/math] и позиции [math]x[/math], это длина максимального префикса подстроки, начинающейся с позиции [math]x[/math] в строке [math]S[/math], который одновременно является и префиксом всей строки [math]S[/math].

Алгоритм поиска

  • Задача

Дана строка [math]S[/math]. Необходимо построить массив [math]Z[/math], такой что [math]Z[i][/math] является префикс функцией данной строки с позиции [math]i[/math]

  • Описание алгоритма
  • Код алгоритма
 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;
}