Перечислимые языки — различия между версиями
Строка 11: | Строка 11: | ||
{{Определение | {{Определение | ||
|definition = | |definition = | ||
− | Пусть имеется некоторая программа <tex>p</tex>, которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Тогда запуск программы <tex>p</tex> с тайм-лимитом <tex>TL</tex> будем обозначать как <tex>p|_{TL}</tex> и иметь в виду следующее: если за <tex>TL</tex> операций программа <tex>p</tex> корректно завершилась и что-то вернула, то <tex>p|_{TL}</tex> вернет то же самое; если же за <tex>TL</tex> операций программа <tex>p</tex> не успела завершиться, то <tex>p|_{TL}</tex> вернет <tex>\bot</tex> ( | + | Пусть имеется некоторая программа <tex>p</tex>, которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Тогда запуск программы <tex>p</tex> с тайм-лимитом <tex>TL</tex> будем обозначать как <tex>p|_{TL}</tex> и иметь в виду следующее: если за <tex>TL</tex> операций программа <tex>p</tex> корректно завершилась и что-то вернула, то <tex>p|_{TL}</tex> вернет то же самое; если же за <tex>TL</tex> операций программа <tex>p</tex> не успела завершиться, то <tex>p|_{TL}</tex> вернет <tex>\bot</tex> (символ зависания). |
}} | }} | ||
Строка 20: | Строка 20: | ||
<tex>L-</tex> перечислимый <tex>\Leftrightarrow L-</tex> полуразрешимый. | <tex>L-</tex> перечислимый <tex>\Leftrightarrow L-</tex> полуразрешимый. | ||
|proof= | |proof= | ||
− | Пусть <tex>L-</tex> перечислимый. | + | Пусть <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> полуразрешимый. | + | Пусть <tex>L-</tex> полуразрешимый язык. Докажем, что он перечислим, приведя соответствующую программу. |
<tex>g_0(i):</tex> | <tex>g_0(i):</tex> | ||
<tex>cnt = 0</tex> | <tex>cnt = 0</tex> | ||
for <tex> k = 1 ~ .. ~ \infty</tex> | for <tex> k = 1 ~ .. ~ \infty</tex> | ||
for <tex> x \in \{x_1, x_2, .., x_k\}</tex> | for <tex> x \in \{x_1, x_2, .., x_k\}</tex> | ||
− | if <tex> p|_k( | + | if <tex> p|_k(x) == 1</tex> |
<tex>cnt</tex>++ | <tex>cnt</tex>++ | ||
if <tex> cnt == i</tex> | if <tex> cnt == i</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>U</tex>, хранятся все выведенные на данный момент слова языка <tex>L</tex>. | ||
+ | |||
Приведённые программы доказывают эквивалентность определений. | Приведённые программы доказывают эквивалентность определений. | ||
}} | }} | ||
Строка 49: | Строка 51: | ||
|id=th2 | |id=th2 | ||
|statement= | |statement= | ||
− | Любой разрешимый язык <tex>L</tex> является перечислимым. | + | Любой [[Разрешимые_(рекурсивные)_языки | разрешимый язык]] <tex>L</tex> является перечислимым. |
|proof= | |proof= | ||
Любой разрешимый язык <tex>L</tex> является полуразрешимым. А так как любой полуразрешимый язык является перечислимым, то разрешимый язык <tex>L</tex> является перечислимым. | Любой разрешимый язык <tex>L</tex> является полуразрешимым. А так как любой полуразрешимый язык является перечислимым, то разрешимый язык <tex>L</tex> является перечислимым. | ||
}} | }} | ||
+ | |||
+ | == Литература == | ||
+ | Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. -- М.: МЦНМО, 1999 |
Версия 01:24, 19 декабря 2011
Определение: |
Полуразрешимый язык | язык, для которого существует программа такая, что .
Определение: |
Перечислимый язык | язык, для которого существует программа такая, что .
Определение: |
Пусть имеется некоторая программа | , которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Тогда запуск программы с тайм-лимитом будем обозначать как и иметь в виду следующее: если за операций программа корректно завершилась и что-то вернула, то вернет то же самое; если же за операций программа не успела завершиться, то вернет (символ зависания).
Теорема: |
перечислимый полуразрешимый. |
Доказательство: |
Пусть перечислимый язык. Докажем, что он полуразрешим, приведя соответствующую программу.for if return Пусть полуразрешимый язык. Докажем, что он перечислим, приведя соответствующую программу.for for if ++ if return for if ++ if return На каждой итерации цикла программы Приведённые программы доказывают эквивалентность определений. , в множестве , хранятся все выведенные на данный момент слова языка . |
Теорема: |
Любой разрешимый язык является перечислимым. |
Доказательство: |
Любой разрешимый язык | является полуразрешимым. А так как любой полуразрешимый язык является перечислимым, то разрешимый язык является перечислимым.
Литература
Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. -- М.: МЦНМО, 1999