Упражнение 2.1.25 |
Алгоритмические проблемы
Упражнение 14.1.20. Рассмотрим детерминированную машину Тьюринга, изображенную на рисунке.
![\objectwidth={5mm} \objectheight={5mm} \let\objectstyle=\scriptstyle
\xymatrix {
*=[o][F-]{1}
\ar @`{+/l16mm/} [] ^{}
\ar "1,2" ^{b:b\dr}
& *=[o][F-]{2}
\ar "1,3" ^{a:b\dr}
\ar "2,3" _{b:b\dn}
& *=[o][F-]{3}
\ar "1,4" ^{a:b\dr}
\ar "2,3" ^{b:b\dn}
& *=[o][F-]{4}
\ar "1,5" ^{a:b\dr}
\ar "2,3" ^{b:b\dn}
& *=[o][F-]{5}
\rloop{0,1} ^{a:b\dr}
\ar "2,5" ^{b:b\dn}
\\
%
&
& *=[o][F=]{6}
&
& *=[o][F=]{7}
}](/sites/default/files/tex_cache/096a0b090cd17343003bddf24a963431.png)


Упражнение 14.1.21. Рассмотрим детерминированную машину Тьюринга, изображенную на рисунке.
![\objectwidth={5mm} \objectheight={5mm} \let\objectstyle=\scriptstyle
\xymatrix {
%
& *=[o][F-]{6}
\rloop{0,1} ^{b:b\dr}
\ar "1,3" ^{a:a\dr}
& *=[o][F-]{7}
\rloop{0,1} ^{a:a\dr}
\ar "2,3" ^{b:a\dl}
&
& *=[o][F-]{1}
\ar @`{+/l16mm/} [] ^{}
\ar "1,6" ^{b:a\dr}
& *=[o][F-]{2}
\rloop{0,1} ^{a:a\dr}
\ar "1,7" ^{b:b\dr}
& *=[o][F-]{3}
\rloop{0,1} ^{a:b\dr}
\ar @/^4mm/ "3,2" ^{b:a\dl}
\\
%
&
& *=[o][F-]{8}
\rloop{0,-1} ^{a:a\dl}
\ar "3,2" _{b:b\dl}
&
&
&
&
\\
*=[o][F-]{5}
\ar "1,2" ^{a:a\dr}
\ar "4,2" _{b:b\dr}
& *=[o][F-]{4}
\rloop{0,-1} ^{b:b\dl}
\ar "3,1" _{a:b\dl}
&
&
& *=[o][F-]{10}
\ar "4,7" ^{b:a\dr}
&
&
\\
%
& *=[o][F-]{9}
\rloop{0,-1} ^{a:b\dl}
\ar "3,5" ^{b:b\dr}
& *=[o][F-]{15}
\rloop{0,-1} ^{a:a\dl}
\ar "4,5" ^{b:a\dr}
&
& *=[o][F-]{16}
\rloop{0,1} ^{a:a\dr}
\ar "4,7" ^{b:b\dr}
&
& *=[o][F-]{11}
\rloop{0,1} ^{b:b\dr}
\ar "5,6" ^{a:a\dl}
\\
%
&
&
& *=[o][F-]{14}
\rloop{0,-1} ^{b:b\dl}
\ar "4,3" ^(0.3){a:a\dl}
& *=[o][F-]{13}
\ar "5,4" ^{b:b\dl}
\ar "6,4" ^{a:b\dl}
& *=[o][F-]{12}
\ar "5,5" ^{b:a\dl}
\ar "6,7" ^(0.3){a:b\dr}
&
\\
%
&
&
& *=[o][F-]{17}
\ar "4,2" ^{a:b\dl}
\ar "6,7" ^{b:b\dr}
&
&
& *=[o][F-]{18}
\rloop{0,1} ^{b:b\dr}
\ar "7,7" ^{a:b\dn}
\\
%
&
&
&
&
&
& *=[o][F=]{19}
}](/sites/default/files/tex_cache/5fd0c2fbd44abc5ee33e0da0c80994f4.png)


14.2. Разрешимые и перечислимые множества
Определение 14.2.1. Говорят, что детерминированная машина Тьюринга


1) для каждого слова
найдутся такие
и
,
что
;
2) для каждого слова
найдутся такие
и
,
что
.
Состояние qa
называется допускающим
( принимающим, accept state),
состояние qr
называется отвергающим
( непринимающим, (reject state).
Пример 14.2.2. Рассмотрим детерминированную машину Тьюринга









![\objectwidth={5mm} \objectheight={5mm} \let\objectstyle=\scriptstyle
\xymatrix {
*=[o][F-]{0}
\ar @`{+/l16mm/} [] ^{}
\ar "1,2" ^{b:b\dr}
& *=[o][F-]{1}
\ar "1,3" ^{a:b\dr}
\ar "2,2" ^{b:b\dn}
& *=[o][F-]{2}
\ar "1,4" ^{a:b\dr}
\ar "2,4" _{b:b\dn}
& *=[o][F-]{3}
\ar `ul^l{+/u7mm/}`l^dl{[0,-2]}_{a:b\dr} "1,2"
\ar "2,4" ^{b:b\dn}
\\
%
& *=[o][F=]{4}
&
& *=[o][F=]{5}
}](/sites/default/files/tex_cache/90f70974fb81f4579c8b0e5c50860750.png)

Определение 14.2.3.
Язык L
над алфавитом
называется разрешимым
или рекурсивным (decidable, recursive),
если
существует детерминированная машина Тьюринга

Определение 14.2.4. Говорят, что машина Тьюринга





Определение 14.2.5. Язык, допускаемый машиной Тьюринга M, - это язык, состоящий из всех допускаемых данной машиной Тьюринга слов.
Определение 14.2.6. Язык называется перечислимым ( рекурсивно перечислимым, полуразрешимым, recursively enumerable), если существует детерминированная машина Тьюринга, допускающая этот язык.
Замечание 14.2.7. В определении 14.2.6 можно отбросить требование детерминированности машины Тьюринга.
Теорема 14.2.8. Каждый разрешимый язык является перечислимым.
Доказательство. Пусть дана машина Тьюринга



Пример 14.2.9.
Если в машине Тьюринга
из примера 14.1.15
заменить переход
на
,
то получится машина Тьюринга, допускающая язык
.
Следовательно,
этот язык является перечислимым.
Можно доказать, что он даже является разрешимым.
Теорема 14.2.10. Существует такая машина Тьюринга
над однобуквенным алфавитом , что язык, допускаемый этой машиной Тьюринга,
неразрешим.
Доказательство. Доказательство существования перечислимого неразрешимого множества можно найти, например, в [31, 9.2].
Упражнение 14.2.11.
Найти детерминированную машину Тьюринга
с входным алфавитом {a},
разрешающую язык .
Упражнение 14.2.12.
Найти детерминированную машину Тьюринга
с входным алфавитом {a},
допускающую язык