Слово Фибоначчи — различия между версиями
AMaltsev (обсуждение | вклад) м |
AMaltsev (обсуждение | вклад) м |
||
| Строка 1: | Строка 1: | ||
{{Определение | {{Определение | ||
| − | |definition='''Строками Фибоначчи''' (англ. ''Fibostring'') называются строки над алфавитом <tex>\Sigma = \{ | + | |definition='''Строками Фибоначчи''' (англ. ''Fibostring'') называются строки над алфавитом <tex>\Sigma = \{x, y\}</tex>, полученные последовательным применением морфизма <tex>h</tex>: |
| − | * <tex>h( | + | * <tex>h(x) = xy</tex> |
| − | * <tex>h( | + | * <tex>h(y) = x</tex> |
| − | к строке <tex>s = | + | к строке <tex>s = y</tex>, т. е. последовательность <tex>f_n(x,y) = h^n(b)</tex>. |
}} | }} | ||
| Строка 22: | Строка 22: | ||
|statement= Строки Фибоначчи удовлетворяют рекуррентному соотношению <tex>f_n = f_{n-1}f_{n-2}, n \geqslant 2</tex>. | |statement= Строки Фибоначчи удовлетворяют рекуррентному соотношению <tex>f_n = f_{n-1}f_{n-2}, n \geqslant 2</tex>. | ||
|proof= | |proof= | ||
| − | Докажем методом математической индукции | + | Докажем методом математической индукции по <tex>f_n</tex> |
| − | '''База:''' | + | '''База:''' |
| − | '''Переход:''' Пусть <tex>n > 2</tex> и <tex>f_n = f_{n-1}f_{n-2}</tex>. <tex>f_{n+1} = h(f_n) = h(f_{n-1}f_{n-2})</tex>. Так как отображение <tex>h</tex> {{---}} линейно (т.е. <tex>h(xy) = h(x)h(y)</tex>), то можно продолжить равенство: | + | *: При <tex>n = 2</tex> <tex>f_2=ab=f_1f_0</tex>. |
| − | <tex>f_{n+1} = h(f_{n-1})h(f_{n-2}) = f_{n}f_{n-1}</tex>. | + | |
| + | '''Переход:''' | ||
| + | |||
| + | *:Пусть <tex>n > 2</tex> и <tex>f_n = f_{n-1}f_{n-2}</tex>. <tex>f_{n+1} = h(f_n) = h(f_{n-1}f_{n-2})</tex>. | ||
| + | *:Так как отображение <tex>h</tex> {{---}} линейно (т.е. <tex>h(xy) = h(x)h(y)</tex>), то можно продолжить равенство: | ||
| + | *:<tex>f_{n+1} = h(f_{n-1})h(f_{n-2}) = f_{n}f_{n-1}</tex>. | ||
}} | }} | ||
| Строка 33: | Строка 38: | ||
| − | == | + | ==Свойства строк Фибоначчи== |
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
{{Определение | {{Определение | ||
| Строка 59: | Строка 46: | ||
{{Лемма | {{Лемма | ||
|about = 2 | |about = 2 | ||
| − | |statement=<tex>f_n = f_{n-k}(f_{k+1},f_k)</tex> | + | |statement= Для любого целого <tex>k \geqslant 0</tex> выполняется <tex>f_n = f_{n-k}(f_{k+1},f_k)</tex>. |
| − | |proof= <tex>h^n(y) = h^{n-k}(h^k(y))</tex> | + | |proof= <tex>f_n(x,y) = h^n(y) = h^{n-k}(h^k(y))</tex> |
<tex>f_n(x,y) = h^k(f_{n-k}(x,y)) = f_{n-k}(h^k(x),h^k(y)) = f_{n-k}(h^{k+1}(y),h^k(y))</tex>. | <tex>f_n(x,y) = h^k(f_{n-k}(x,y)) = f_{n-k}(h^k(x),h^k(y)) = f_{n-k}(h^{k+1}(y),h^k(y))</tex>. | ||
| Строка 77: | Строка 64: | ||
|proof = Докажем это утверждение методом математической индукции. | |proof = Докажем это утверждение методом математической индукции. | ||
| − | '''База.''' <tex>f_0f_1 \neq f_1f_0 | + | '''База.''' |
| − | + | *:<tex>f_0f_1 \neq f_1f_0</tex> | |
| − | |||
| − | |||
| − | |||
| − | Но то, что <tex> f_{n-2}f_{n-1} \neq f_{n-1}f_{n-2} </tex> было доказано ранее в ходе индукции. | + | '''Переход.''' |
| + | *:<tex>f_nf_{n+1}=f_nf_nf_{n-1}=f_nf_{n-1}f_{n-2}f_{n-1}</tex> | ||
| + | *:<tex>f_{n+1}f_n=f_nf_{n-1}f_n=f_nf_{n-1}f_{n-1}f_{n-2}</tex> | ||
| + | *:Но то, что <tex> f_{n-2}f_{n-1} \neq f_{n-1}f_{n-2} </tex> было доказано ранее в ходе индукции. | ||
}} | }} | ||
{{Лемма | {{Лемма | ||
Версия 01:02, 9 июня 2016
| Определение: |
| Строками Фибоначчи (англ. Fibostring) называются строки над алфавитом , полученные последовательным применением морфизма :
|
Содержание
Примеры
Первые несколько строк Фибоначчи:
Рекуррентное соотношение для строк Фибоначчи
| Лемма (1): |
Строки Фибоначчи удовлетворяют рекуррентному соотношению . |
| Доказательство: |
|
Докажем методом математической индукции по База:
Переход:
|
Также можно заметить, что длины строк Фибоначчи совпадают с числами Фибоначчи.
Свойства строк Фибоначчи
| Определение: |
| Определим бесконечную обобщенную строку Фибоначчи (англ. generalized infinite Fibostring) как строку, содержащую все строки в качестве префиксов. |
| Лемма (2): |
Для любого целого выполняется . |
| Доказательство: |
|
. |
Например: .
Это равенство работает также для .
| Утверждение (1): |
В не может содержаться подстроки или . |
| Утверждение (2): |
Для любого . |
|
Докажем это утверждение методом математической индукции. База. Переход.
|
| Лемма (3): |
Для любого целого выполняется равенство . |
| Доказательство: |
| . |
| Лемма (4): |
Для любого целого строка имеет бордеры для . |
Обратный морфизм
| Определение: |
Обратный морфизм определяется как отображение:
|
Обратный морфизм позволяет из строки получить строку .
Связь с задачей о построении исключений
| Утверждение (3): |
Для любого целого содержит куб некоторой подстроки. |
| Строка содержит подстроку и является префиксом для . |
| Теорема (1): |
Никакая строка не содержит подстроки кратности . |
| Утверждение (4): |
Бесконечная строка Фибоначчи является решением задачи построения -исключения |
| Это следует из утверждения и теоремы выше. |
См. также
Источники
- Билл Смит «Методы и алгоритмы вычислений на строках» — издательство «Вильямс» — 2006 — стр. 100-107