Период и бордер, их связь — различия между версиями
Martoon (обсуждение | вклад) м (→Теорема о НОД периодов) |
Martoon (обсуждение | вклад) (→Теорема о НОД периодов) |
||
| Строка 57: | Строка 57: | ||
{{Лемма | {{Лемма | ||
|about=1 | |about=1 | ||
| − | |statement= Пусть строка <tex> s </tex> имеет периоды <tex> p </tex> и <tex> q </tex>, причём <tex> p | + | |statement= Пусть строка <tex> s </tex> имеет периоды <tex> p </tex> и <tex> q </tex>, причём <tex> q < p \leqslant |s| </tex>. Тогда суффикс и префикс <tex> s </tex> длины <tex> |s| - q </tex> имеют период <tex> p - q </tex>. |
|proof= Покажем истинность утверждения про префикс; с суффиксом доказательство аналогичное. | |proof= Покажем истинность утверждения про префикс; с суффиксом доказательство аналогичное. | ||
| Строка 73: | Строка 73: | ||
Требуется показать: <tex> s_i = s_j \ (j = i + r,\ 1 \leqslant i, j \leqslant n) </tex>. | Требуется показать: <tex> s_i = s_j \ (j = i + r,\ 1 \leqslant i, j \leqslant n) </tex>. | ||
| − | Заметим, что поскольку <tex> |v| \geqslant q </tex> отрезок <tex> [h, k] </tex> содержит по меньшей мере <tex> q </tex> целых чисел, так что найдутся <tex> i',\ j' \in [h, k]: \ \ i \equiv i' \pmod q,\ j \equiv j' \pmod q </tex>. | + | Зафиксируем <tex> i </tex> и <tex> j </tex>. Заметим, что поскольку <tex> |v| \geqslant q </tex>, отрезок <tex> [h, k] </tex> содержит по меньшей мере <tex> q </tex> целых чисел, так что найдутся <tex> i',\ j' \in [h, k]: \ \ i \equiv i' \pmod q,\ j \equiv j' \pmod q,\ i \ne j </tex>. |
С учётом <tex> q </tex> <tex dpi=90>\,\vdots\, </tex> <tex> r </tex> можем написать <tex> i \equiv i' \pmod r,\ j \equiv j' \pmod r </tex> <ref>[[Сравнения,_система_вычетов,_решение_линейных_систем_по_модулю#Свойства сравнений | Свойство сравнений (№8)]]</ref>. | С учётом <tex> q </tex> <tex dpi=90>\,\vdots\, </tex> <tex> r </tex> можем написать <tex> i \equiv i' \pmod r,\ j \equiv j' \pmod r </tex> <ref>[[Сравнения,_система_вычетов,_решение_линейных_систем_по_модулю#Свойства сравнений | Свойство сравнений (№8)]]</ref>. | ||
| Строка 90: | Строка 90: | ||
|author=Фин и Вильф | |author=Фин и Вильф | ||
|proof=Обозначим <tex> r = \gcd(p, q) </tex>. Доказательство будем вести индукцией по <tex> n = (p + q) / r </tex>. | |proof=Обозначим <tex> r = \gcd(p, q) </tex>. Доказательство будем вести индукцией по <tex> n = (p + q) / r </tex>. | ||
| + | |||
| + | В случае <tex> p = q </tex> видим что <tex> n = 2 </tex>, что соответствует базе, в то время как при <tex> p \ne q </tex> выполнено <tex> p, q > \gcd(p, q) </tex>, так что <tex> n > 2 </tex>. | ||
* База | * База | ||
| − | *: | + | *: Истинность утверждения следует из <tex> p = q = r </tex>. |
* Переход | * Переход | ||
| − | *: | + | *: В силу того, что <tex> p \ne q </tex>, без ограничения общности будем считать <tex> q < p </tex> (вообще говоря, исходя из свойств НОД можно дать более строгую оценку: <tex> p - q \geqslant r </tex>, чем мы позже воспользуемся). |
*: Пусть <tex> w = uv </tex>, где <tex> |u| = q </tex>. | *: Пусть <tex> w = uv </tex>, где <tex> |u| = q </tex>. | ||
*: По '''лемме 1''' <tex> v </tex> имеет период <tex> p - q </tex>, также <tex> v </tex> имеет период <tex> q </tex> как подстрока <tex> w </tex>. Теперь рассмотрим длину <tex> v </tex>: | *: По '''лемме 1''' <tex> v </tex> имеет период <tex> p - q </tex>, также <tex> v </tex> имеет период <tex> q </tex> как подстрока <tex> w </tex>. Теперь рассмотрим длину <tex> v </tex>: | ||
*: <tex> |v| = |w| - q \geqslant (p + q - r) - q \geqslant (p - q) + q - r = (p - q) + q - \gcd(p - q, q) </tex>. | *: <tex> |v| = |w| - q \geqslant (p + q - r) - q \geqslant (p - q) + q - r = (p - q) + q - \gcd(p - q, q) </tex>. | ||
| − | *: | + | *: Ещё заметим, что для периодов <tex> p - q,\ q </tex> будет меньшее <tex> n </tex>, нежели чем для <tex> p,\ q </tex>, поскольку <tex> \gcd(p-q, q) = \gcd(p, q) </tex>. А тогда по предположению индукции заключаем: <tex> v </tex> имеет период <tex> \gcd(p-q, q)</tex>. Учитывая <tex> \gcd(p-q, q) = \gcd(p, q) = r </tex>, можем сказать что <tex> v </tex> имеет период <tex> r </tex>. |
| − | *: | + | *: Как уже упоминалось, <tex> p - q \geqslant r </tex>, поэтому <tex> |v| \geqslant (p - q) + q - r \geqslant q </tex>, в следствие чего по '''лемме 2''' <tex> w </tex> имеет период <tex> r </tex>. |
}} | }} | ||
Версия 22:22, 4 июня 2014
Содержание
Определения
| Определение: |
| Строка называется бордером строки , если одновременно является и суффиксом, и префиксом . |
| Определение: |
| Число называется периодом строки , если . |
Связь периода и бордера
| Теорема: |
Если у строки длины есть бордер длины , то у нее также имеется период длины . |
| Доказательство: |
|
Пусть дана строка . Напишем формально определение бордера длины строки : Сделаем замену : |
Свойства периода
Теорема о кратном периоде
| Теорема: |
Если у строки есть период длины , то у нее имеется также период длины , где . |
| Доказательство: |
|
Пусть длина строки равна , сама строка — . Доказательство будем вести индукцией по числу .
|
Теорема о НОД периодов
Перед доказательством следующей теоремы проверим пару интуитивно понятных утверждений.
| Лемма (1): |
Пусть строка имеет периоды и , причём . Тогда суффикс и префикс длины имеют период . |
| Доказательство: |
|
Покажем истинность утверждения про префикс; с суффиксом доказательство аналогичное. Требуется показать: Исходя из того, что имеет период , выполнено Также имеет период и из ограничений на верно , поэтому |
| Лемма (2): |
Пусть строка имеет период , и существует подстрока такая, что и имеет период , где . Тогда имеет период . |
| Доказательство: |
|
Пусть , где . Требуется показать: . Зафиксируем и . Заметим, что поскольку , отрезок содержит по меньшей мере целых чисел, так что найдутся . С учётом можем написать [1]. Помимо того , а в таком случае верно и . Теперь воспользуемся следующим фактом: если строка имеет период , то (действительно, без ограничения общности можем сказать, что , и исходя из этого выстроить цепочку равенств ). В виду того, что имеет период , имеют место равенства и . Кроме того имеет период , потому верно . Тогда и . |
| Теорема (Фин и Вильф): |
Если у строки есть периоды и , где , то также является периодом этой строки. |
| Доказательство: |
|
Обозначим . Доказательство будем вести индукцией по . В случае видим что , что соответствует базе, в то время как при выполнено , так что .
|
См. также
Примечания
Литература
- Wikipedia — Substring
- Lothaire M. Algebraic Combinatorics on Words — Cambridge University Press, 2002. — с. 272. — ISBN 0-521-81220-8