Период и бордер, их связь — различия между версиями
Martoon (обсуждение | вклад) м |
Martoon (обсуждение | вклад) м (→Теорема о НОД периодов) |
||
Строка 53: | Строка 53: | ||
==Теорема о НОД периодов== | ==Теорема о НОД периодов== | ||
− | Перед доказательством следующей теоремы | + | Перед доказательством следующей теоремы проверим пару интуитивно понятных утверждений. |
{{Лемма | {{Лемма | ||
Строка 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> |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> 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>. | ||
Строка 79: | Строка 79: | ||
Помимо того <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> s </tex> имеет период <tex> r </tex>, то <tex> i \equiv j \pmod r \ \Rightarrow\ s_i = s_j </tex> (действительно, без ограничения общности можем сказать, что <tex> i \leqslant j </tex>, исходя из | + | Теперь воспользуемся следующим фактом: если строка <tex> s </tex> имеет период <tex> r </tex>, то <tex> i \equiv j \pmod r \ \Rightarrow\ s_i = s_j </tex> (действительно, без ограничения общности можем сказать, что <tex> i \leqslant j </tex>, и исходя из этого выстроить цепочку равенств <tex> s_i = s_{i + r},\ \ s_{i + r} = s_{i + 2r},\ \ \dots \ , \ s_{j - r} = s_j </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>. | В виду того, что <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>. |
Версия 19:16, 25 мая 2014
Содержание
Определения
Определение: |
Строка суффиксом, и префиксом . | называется бордером строки , если одновременно является и
Определение: |
Число | называется периодом строки , если .
Связь периода и бордера
Теорема: |
Если у строки длины есть бордер длины , то у нее также имеется период длины . |
Доказательство: |
Пусть дана строка .Напишем формально определение бордера длины строки :Сделаем замену : |
Свойства периода
Теорема о кратном периоде
Теорема: |
Если у строки есть период длины , то у нее имеется также период длины , где . |
Доказательство: |
Пусть длина строки равна , сама строка — .Доказательство будем вести индукцией по числу .
|
Теорема о НОД периодов
Перед доказательством следующей теоремы проверим пару интуитивно понятных утверждений.
Лемма (1): |
Пусть строка имеет периоды и , причём . Тогда суффикс и префикс длины имеют период . |
Доказательство: |
Покажем истинность утверждения про префикс; с суффиксом доказательство аналогичное. Требуется показать: Исходя из того, что Также имеет период , выполнено имеет период и из ограничений на верно , поэтому |
Лемма (2): |
Пусть строка имеет период , и существует подстрока такая, что и имеет период , где . Тогда имеет период . |
Доказательство: |
Пусть , где .Требуется показать: .Заметим, что поскольку отрезок содержит по меньшей мере целых чисел, так что найдутся .С учётом [1]. можем написатьПомимо того , а в таком случае верно и .Теперь воспользуемся следующим фактом: если строка В виду того, что имеет период , то (действительно, без ограничения общности можем сказать, что , и исходя из этого выстроить цепочку равенств ). имеет период , имеют место равенства и . Кроме того имеет период , потому верно . Тогда и . |
Теорема (Фин и Вильф): |
Если у строки есть периоды и , где , то также является периодом этой строки. |
Доказательство: |
Обозначим . Доказательство будем вести индукцией по .
|
См. также
Примечания
Литература
- Wikipedia — Substring
- Lothaire M. Algebraic Combinatorics on Words — Cambridge University Press, 2002. — с. 272. — ISBN 0-521-81220-8