Замкнутость разрешимых и перечислимых языков относительно теоретико-множественных и алгебраических операций — различия между версиями
Vincent (обсуждение | вклад) |
|||
Строка 115: | Строка 115: | ||
{{Теорема | {{Теорема | ||
|statement= | |statement= | ||
− | Языки <tex> L_1 </tex> и <tex> L_2 </tex> {{---}} перечислимы, тогда следующие языки могут быть | + | Языки <tex> L_1 </tex> и <tex> L_2 </tex> {{---}} перечислимы, тогда следующие языки могут быть неперечислимы: |
* <tex>\overline{L_1}</tex> {{---}} дополнение <tex>L_1\</tex>; | * <tex>\overline{L_1}</tex> {{---}} дополнение <tex>L_1\</tex>; | ||
Строка 122: | Строка 122: | ||
|proof= | |proof= | ||
− | Рассмотрим язык <tex> \overline{L_1} </tex>. Предположим, что он перечислим. Тогда, имея какое-либо слово, мы можем одновременно запустить перечислители для <tex> L_1 </tex> и <tex> \overline{L_1} </tex>. В какой-то момент времени слово появится либо в выводе перечислителя для <tex> L_1 </tex>, либо в выводе перечислителя для <tex> \overline{L_1} </tex>. Тогда получится, что <tex> L_1 </tex> разрешим, так как про любое слово можно сказать, принадлежит ли оно <tex> L_1 </tex> или нет. Но мы знаем, что [[Разрешимые (рекурсивные) языки#Пример неразрешимого множества|существуют перечислимые, но неразрешимые языки]], следовательно, язык <tex> \overline{L_1} </tex> может быть | + | Рассмотрим язык <tex> \overline{L_1} </tex>. Предположим, что он перечислим. Тогда, имея какое-либо слово, мы можем одновременно запустить перечислители для <tex> L_1 </tex> и <tex> \overline{L_1} </tex>. В какой-то момент времени слово появится либо в выводе перечислителя для <tex> L_1 </tex>, либо в выводе перечислителя для <tex> \overline{L_1} </tex>. Тогда получится, что <tex> L_1 </tex> разрешим, так как про любое слово можно сказать, принадлежит ли оно <tex> L_1 </tex> или нет. Но мы знаем, что [[Разрешимые (рекурсивные) языки#Пример неразрешимого множества|существуют перечислимые, но неразрешимые языки]], следовательно, язык <tex> \overline{L_1} </tex> может быть неперечислим. |
Теперь рассмотрим <tex> L_1 \backslash L_2 </tex>. В качестве <tex> L_1 </tex> возьмем язык, состоящий из всех слов. Тогда получится, что <tex> L_1 \backslash L_2 </tex> {{---}} это <tex> \overline{L_2} </tex>. Про <tex> \overline{L_2} </tex> мы знаем, что он перечислим не всегда, следовательно и <tex> L_1 \backslash L_2 </tex> не всегда перечислим. | Теперь рассмотрим <tex> L_1 \backslash L_2 </tex>. В качестве <tex> L_1 </tex> возьмем язык, состоящий из всех слов. Тогда получится, что <tex> L_1 \backslash L_2 </tex> {{---}} это <tex> \overline{L_2} </tex>. Про <tex> \overline{L_2} </tex> мы знаем, что он перечислим не всегда, следовательно и <tex> L_1 \backslash L_2 </tex> не всегда перечислим. |
Версия 10:59, 23 декабря 2011
Теорема: |
Языки разрешимы, тогда следующие языки разрешимы:
и —
|
Доказательство: |
Пусть и — разрешающие программы для языков и соответственно. Для доказательства достаточно написать разрешающую программу (разрешитель) для каждого случая.
return
return
return
return
return
forall , где — множество всевозможных разбиений слова на подстроки if return 1 return 0 Разрешитель будет перебирать все возможные разбиения данного ему слова на подстроки и для каждой проверять принадлежность . Если хотя бы в одном разбиении все подстроки будут принадлежать , то все слово принадлежит , иначе — не принадлежит.
Разрешитель будет перебирать все возможные разбиения на два слова и проверять принадлежность первого слова forall , где — множество всевозможных разбиений слова на две подстроки if return 1 return 0 и второго слова . Если хотя бы для одного разбиения оба разрешителя вернут 1, то слово принадлежит , иначе — не принадлежит. |
Теорема: |
Языки перечислимы, тогда следующие языки перечислимы:
и —
|
Доказательство: |
Пусть и — полуразрешающие программы для языков и соответственно. Для доказательства достаточно написать полуразрешающую программу для каждого случая. Заметим, что и могут зависнуть при использовании в полуразрешающей программе для соответствующего языка, но это допустимо.
for if return 1
if return 1
if return 1
for forall , где — множество всевозможных разбиений слова на подстроки if return 1
for forall , где — множество всевозможных разбиений слова на две подстроки if return 1 |
Теорема: |
Языки и — перечислимы, тогда следующие языки могут быть неперечислимы:
|
Доказательство: |
Рассмотрим язык существуют перечислимые, но неразрешимые языки, следовательно, язык может быть неперечислим. Теперь рассмотрим . Предположим, что он перечислим. Тогда, имея какое-либо слово, мы можем одновременно запустить перечислители для и . В какой-то момент времени слово появится либо в выводе перечислителя для , либо в выводе перечислителя для . Тогда получится, что разрешим, так как про любое слово можно сказать, принадлежит ли оно или нет. Но мы знаем, что . В качестве возьмем язык, состоящий из всех слов. Тогда получится, что — это . Про мы знаем, что он перечислим не всегда, следовательно и не всегда перечислим. |
Литература
- Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. — М.: МЦНМО, 1999. С. 134. ISBN 5-900916-36-7