Период и бордер, их связь — различия между версиями
Martoon (обсуждение | вклад) м (→Свойства периода) |
Martoon (обсуждение | вклад) м (→Свойства периода) |
||
Строка 48: | Строка 48: | ||
− | Перед доказательством следующей теоремы | + | Перед доказательством следующей теоремы докажем пару интуитивно понятных утверждений. |
{{Лемма | {{Лемма | ||
Строка 74: | Строка 74: | ||
Помимо того <tex> i \equiv j \pmod r </tex>, тогда верно и <tex> i' \equiv j' \pmod r </tex>. | Помимо того <tex> i \equiv j \pmod r </tex>, тогда верно и <tex> i' \equiv j' \pmod r </tex>. | ||
− | Теперь, поскольку <tex> w </tex> имеет период <tex> q </tex>, | + | Теперь, поскольку <tex> w </tex> имеет период <tex> q </tex>, имеют место равенства <tex> s_i = s_{i'}\ </tex> и <tex>\ s_j = s_{j'} </tex>. Поскольку <tex> v </tex> имеет период <tex> r </tex>, верно <tex> s_{i'} = s_{j'} </tex>. Тогда и <tex> s_i = s_j </tex>. |
}} | }} | ||
Строка 84: | Строка 84: | ||
|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> n = 1 </tex> видно, что <tex> p = q = r </tex> и утверждение истинно. | + | *: При <tex> n = 1 </tex> видно, что <tex> p = q = r </tex> и потому утверждение истинно. |
* Переход | * Переход | ||
− | *: Заметим что теперь <tex> q \ne p </tex>, поэтому без ограничения общности можем сказать что | + | *: Заметим что теперь <tex> q \ne p </tex> (так как <tex> n \ne 1 </tex>), поэтому без ограничения общности можем сказать, что <tex> q < p </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) + q - r = (p - q) + q - \gcd(p - q, q) </tex>. | *: <tex> |v| = |w| - q \geqslant (p - q) + q - r = (p - q) + q - \gcd(p - q, 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> 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> p > q </tex> и по свойствам НОД), поэтому <tex> |v| = |w| - q \geqslant (p + q - r) - q \geqslant q + (p - q) - r \geqslant q </tex>, тогда по лемме 2 <tex> w </tex> имеет период <tex> r </tex>. | + | *: Ещё заметим, что <tex> p - q \geqslant r </tex> (<tex> p > q </tex> и по свойствам НОД), поэтому <tex> |v| = |w| - q \geqslant (p + q - r) - q \geqslant q + (p - q) - r \geqslant q </tex>, тогда по '''лемме 2''' <tex> w </tex> имеет период <tex> r </tex>. |
}} | }} |
Версия 16:58, 9 мая 2014
Определения
Определение: |
Строка суффиксом, и префиксом . | называется бордером строки , если одновременно является и
Определение: |
Число | называется периодом строки , если .
Связь периода и бордера
Теорема: |
есть |
Доказательство: |
Пусть дана строка Сделаем замену |
Свойства периода
Теорема: |
Если у строки есть период длины , то у нее есть период длины , где . |
Доказательство: |
Пусть длина строки равна
|
Перед доказательством следующей теоремы докажем пару интуитивно понятных утверждений.
Лемма (1): |
Пусть строка имеет периоды и , причём . Тогда суффикс и префикс длины имеют период . |
Доказательство: |
Покажем истинность утверждения про префикс; с суффиксом доказательство аналогичное. Требуется показать что Поскольку Также имеет период , выполнено имеет период и из ограничений на верно , поэтому |
Лемма (2): |
Пусть строка имеет период , и существует подстрока такая, что и имеет период , где делится на . Тогда имеет период . |
Доказательство: |
Пусть , где .Требуется показать: .Заметим, что поскольку , то отрезок содержит ровно целых чисел, так что найдутся такие, что .Так как делится на , можем написать .Помимо того Теперь, поскольку , тогда верно и . имеет период , имеют место равенства и . Поскольку имеет период , верно . Тогда и . |
Теорема (Фин и Вильф): |
Если у строки есть периоды и , где , то также является периодом этой строки. |
Доказательство: |
Обозначим . Доказательство будем вести индукцией по .
|
Ограничение
существенно. Например строка имеет периоды и , её длина , и периода у неё нет.