Перечислимые языки — различия между версиями
Vincent (обсуждение | вклад) (→Литература) |
Vincent (обсуждение | вклад) |
||
| Строка 1: | Строка 1: | ||
{{Определение | {{Определение | ||
|definition = | |definition = | ||
| − | '''Полуразрешимый язык''' | + | '''Полуразрешимый язык''' {{---}} язык, для которого существует программа <tex>p</tex> такая, что <tex>\forall x \in L \Leftrightarrow p(x)=1</tex>. |
}} | }} | ||
{{Определение | {{Определение | ||
|definition = | |definition = | ||
| − | '''Перечислимый язык''' | + | '''Перечислимый язык''' {{---}} язык, для которого существует программа <tex>g</tex> такая, что <tex>g(i) = x_i, L = \{x_1, x_2, .., x_n, ..\}</tex>. |
}} | }} | ||
| Строка 18: | Строка 18: | ||
|id=th1 | |id=th1 | ||
|statement= | |statement= | ||
| − | <tex>L | + | <tex>L</tex> {{---}} перечислимый <tex>\Leftrightarrow L</tex> {{---}} полуразрешимый. |
|proof= | |proof= | ||
| − | Пусть <tex>L | + | Пусть <tex>L</tex> {{---}} перечислимый язык. Докажем, что он полуразрешим, приведя соответствующую программу. |
<tex>p(x):</tex> | <tex>p(x):</tex> | ||
for <tex> i = 1 ~ .. ~ \infty</tex> | for <tex> i = 1 ~ .. ~ \infty</tex> | ||
if <tex> g(i) == x</tex> | if <tex> g(i) == x</tex> | ||
return <tex> 1</tex> | return <tex> 1</tex> | ||
| − | Пусть <tex>L | + | Пусть <tex>L</tex> {{---}} полуразрешимый язык. Докажем, что он перечислим, приведя соответствующую программу. |
<tex>g_0(i):</tex> | <tex>g_0(i):</tex> | ||
<tex>cnt = 0</tex> | <tex>cnt = 0</tex> | ||
| Строка 43: | Строка 43: | ||
return <tex> x</tex> | return <tex> x</tex> | ||
<tex>U.insert(x)</tex> | <tex>U.insert(x)</tex> | ||
| − | На каждой итерации цикла программы <tex>g</tex> | + | На каждой итерации цикла программы <tex>g</tex> в множестве <tex>U</tex> хранятся все выведенные на данный момент слова языка <tex>L</tex>. |
Приведённые программы доказывают эквивалентность определений. | Приведённые программы доказывают эквивалентность определений. | ||
| Строка 53: | Строка 53: | ||
Любой [[Разрешимые_(рекурсивные)_языки | разрешимый язык]] <tex>L</tex> является перечислимым. | Любой [[Разрешимые_(рекурсивные)_языки | разрешимый язык]] <tex>L</tex> является перечислимым. | ||
|proof= | |proof= | ||
| − | Любой разрешимый язык <tex>L</tex> является полуразрешимым. | + | Любой разрешимый язык <tex>L</tex> является полуразрешимым. Так как любой полуразрешимый язык является перечислимым, то разрешимый язык <tex>L</tex> является перечислимым. |
}} | }} | ||
== Литература == | == Литература == | ||
* Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. -- М.: МЦНМО, 1999 | * Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. -- М.: МЦНМО, 1999 | ||
Версия 09:36, 19 декабря 2011
| Определение: |
| Полуразрешимый язык — язык, для которого существует программа такая, что . |
| Определение: |
| Перечислимый язык — язык, для которого существует программа такая, что . |
| Определение: |
| Пусть имеется некоторая программа , которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Тогда запуск программы с тайм-лимитом будем обозначать как и иметь в виду следующее: если за операций программа корректно завершилась и что-то вернула, то вернет то же самое; если же за операций программа не успела завершиться, то вернет (символ зависания). |
| Теорема: |
— перечислимый — полуразрешимый. |
| Доказательство: |
|
Пусть — перечислимый язык. Докажем, что он полуразрешим, приведя соответствующую программу. for if return Пусть — полуразрешимый язык. Докажем, что он перечислим, приведя соответствующую программу. for for if ++ if return for if ++ if return На каждой итерации цикла программы в множестве хранятся все выведенные на данный момент слова языка . Приведённые программы доказывают эквивалентность определений. |
| Теорема: |
Любой разрешимый язык является перечислимым. |
| Доказательство: |
| Любой разрешимый язык является полуразрешимым. Так как любой полуразрешимый язык является перечислимым, то разрешимый язык является перечислимым. |
Литература
- Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. -- М.: МЦНМО, 1999