Busy beaver — различия между версиями
AReunov (обсуждение | вклад) |
AReunov (обсуждение | вклад) |
||
Строка 13: | Строка 13: | ||
Пусть <tex>f(n)</tex> представлена своим кодом. | Пусть <tex>f(n)</tex> представлена своим кодом. | ||
Для каждого <tex>n</tex> определим программы вида: | Для каждого <tex>n</tex> определим программы вида: | ||
− | <tex>p_n</tex>: | + | <tex>p_n()</tex>: |
k = десятичная запись числа n | k = десятичная запись числа n | ||
− | f | + | m = f(k) |
− | for i = 1 to | + | '''for''' i = 1 '''to''' m + 1 |
− | + | шаг программы | |
Каждая такая программа делает как минимум <tex>f(n) + 1</tex> шагов. | Каждая такая программа делает как минимум <tex>f(n) + 1</tex> шагов. | ||
− | Длина <tex> | + | Длина <tex>p_n</tex> будет равна <tex> \lg n + const </tex>, где <tex>const</tex> {{---}} длина кода без десятичной записи <tex>n</tex>. Пусть <tex>n_0</tex> {{---}} решение уравнения <tex>\lg n + const = n</tex>. Тогда для всех натуральных <tex> n > \left \lceil n_0 \right \rceil </tex>, в силу неубывания <tex>BB(n)</tex>, будет выполнено: <tex> n > len(p_n) \Rightarrow BB(n) \geqslant BB(len(p_n)) > m = f(n) </tex>. Так как <tex>n_0</tex> конечно, то утверждение доказано. |
}} | }} | ||
Версия 20:03, 14 января 2016
Поиск усердных бобров (англ. busy beaver) — известная задача в теории вычислимости. Под усердным бобром в теории вычислимости понимают машину Тьюринга с заданным числом состояний конечного автомата, которая будучи запущенной на пустой ленте, записывает на нее максимальное количество ненулевых символов и останавливается.
В данном конспекте будет рассмотрена функция, которая используется в этой задаче для подсчета числа шагов для завершения программы при определенном числе состояний.
Определение: |
— функция от натурального аргумента , равная максимальному числу шагов, которое может совершить программа длиной символов и затем остановиться. |
Утверждение: |
вычислимой функции , то есть для всех кроме конечного числа выполнено растет быстрее любой всюду определенной неубывающей |
Пусть представлена своим кодом. Для каждого определим программы вида:
:
k = десятичная запись числа n
m = f(k)
for i = 1 to m + 1
шаг программы
Каждая такая программа делает как минимум Длина шагов. будет равна , где — длина кода без десятичной записи . Пусть — решение уравнения . Тогда для всех натуральных , в силу неубывания , будет выполнено: . Так как конечно, то утверждение доказано. |
Вывод: доказав предыдущее утверждение, мы проверили, что максимальное число шагов, которое может совершить программа и при этом остановиться, на самом деле растет с большей скоростью, чем любая вычислимая функция. Отсюда следует, что
невычислима.См. также
Источники информации
- Хопкрофт Д., Мотвани Р., Ульман Д. — Введение в теорию автоматов, языков и вычислений, 2-е изд. : Пер. с англ. — Москва, Издательский дом «Вильямс», 2002. — 528 с. : ISBN 5-8459-0261-4 (рус.)
- Английская Википедия — Busy beaver
- Федотов П.В., Царев Ф.Н., Шалыто А.А. — Задача поиска усердных бобров и ее решения