Примеры неразрешимых задач: проблема соответствий Поста — различия между версиями
Shevchen (обсуждение | вклад) |
Shevchen (обсуждение | вклад) |
||
Строка 47: | Строка 47: | ||
<tex>a_i = \$</tex>, <tex>b_i = \$</tex>; | <tex>a_i = \$</tex>, <tex>b_i = \$</tex>; | ||
− | для всех правил <tex>M</tex> вида <tex>\delta (p, c) = \langle q, d, \leftarrow \rangle</tex>: | + | для всех правил <tex>M</tex> вида <tex>\delta (p, c) = \langle q, d, \leftarrow \rangle</tex> и для всех символов алфавита <tex>e</tex>: |
− | <tex>a_i = \#_q d</tex>, <tex>b_i = | + | <tex>a_i = \#_q e d</tex>, <tex>b_i = e \#_p c</tex>; |
для всех правил <tex>M</tex> вида <tex>\delta (p, c) = \langle q, d, \rightarrow \rangle</tex>: | для всех правил <tex>M</tex> вида <tex>\delta (p, c) = \langle q, d, \rightarrow \rangle</tex>: | ||
Строка 80: | Строка 80: | ||
}} | }} | ||
+ | |||
+ | === Пример === | ||
+ | |||
+ | Пусть автомат МТ состоит из двух состояний <tex>start</tex> и <tex>yes</tex>, алфавит ленты содержит символы <tex>a</tex> и <tex>b</tex>. Переходы автомата устроены следующим образом: | ||
+ | |||
+ | <tex>\delta (start, a) = \langle start, b, \rightarrow \rangle</tex>; | ||
+ | |||
+ | <tex>\delta (start, b) = \langle yes, b, \downarrow \rangle</tex>; | ||
+ | |||
+ | из <tex>yes</tex> переходов нет. | ||
+ | |||
+ | Последовательности при строке <tex>ab</tex> будут сформированы следующим образом: | ||
+ | |||
+ | {| border="1" | ||
+ | |Номер элемента | ||
+ | |width="45"|1 | ||
+ | |width="45"|2 | ||
+ | |width="45"|3 | ||
+ | |width="45"|4 | ||
+ | |width="45"|5 | ||
+ | |width="45"|6 | ||
+ | |width="45"|7 | ||
+ | |width="45"|8 | ||
+ | |width="45"|9 | ||
+ | |width="45"|10 | ||
+ | |width="45"|11 | ||
+ | |- | ||
+ | |Последовательность a | ||
+ | |<tex>\$ \#_{start} a \$</tex> | ||
+ | |<tex>a</tex> | ||
+ | |<tex>b</tex> | ||
+ | |<tex>\$</tex> | ||
+ | |<tex>b \#_{start}</tex> | ||
+ | |<tex>\#_{yes} b</tex> | ||
+ | |<tex>\#_{yes}</tex> | ||
+ | |<tex>\#_{yes}</tex> | ||
+ | |<tex>\#_{yes}</tex> | ||
+ | |<tex>\#_{yes}</tex> | ||
+ | |<tex>\$ \$</tex> | ||
+ | |- | ||
+ | |Последовательность b | ||
+ | |<tex>\$</tex> | ||
+ | |<tex>a</tex> | ||
+ | |<tex>b</tex> | ||
+ | |<tex>\$</tex> | ||
+ | |<tex>\#_{start} a</tex> | ||
+ | |<tex>\#_{start} b</tex> | ||
+ | |<tex>a \#_{yes}</tex> | ||
+ | |<tex>b \#_{yes}</tex> | ||
+ | |<tex>\#_{yes} a</tex> | ||
+ | |<tex>\#_{yes} b</tex> | ||
+ | |<tex>\#_{yes} \$ \$</tex> | ||
+ | |} | ||
+ | |||
+ | |||
{{Теорема | {{Теорема |
Версия 08:37, 21 января 2012
Определение: |
Дана упорядоченная пара конечных последовательностей | , где и для всех . Вопрос существования непустой последовательности индексов , удовлетворяющей условию , где для каждого j, называется проблемой соответствий Поста (ПСП). Такую последовательность индексов, в случае её существования, называют решением проблемы соответствий Поста.
Определение: |
Проблема соответствий Поста, для которой фиксирован элемент последовательности индексов | , называется модифицированной проблемой соответствий Поста (МПСП).
Утверждение: |
Язык пар последовательностей, для которых существует решение ПСП, перечислим. |
Пусть даны последовательности и размера из условия ПСП. Построим программу-полуразрешитель , проверяющую все возможные решения:forТаким образом, язык пар последовательностей, для которых существует решение ПСП, полуразрешим, а значит, перечислим. for all if return true |
Для МПСП доказательство перечислимости имеющих решение пар аналогично, но перебор индексов ведётся с
.Теорема: |
МПСП неразрешима. |
Доказательство: |
Выполним m-сведение множества пар из машины Тьюринга (МТ) и строки , где не зависает, к множеству решений МПСП. Назовём снимком состояния МТ строку вида , где — строка на ленте без учёта пробелов, — текущее состояние автомата МТ, соответствует положению головки. Построим последовательности таким образом, чтобы решение МПСП образовывало строку, где — снимки последовательных состояний МТ от стартового до конечного, — последний снимок с удалёнными символами строки. Оговоримся, что состояния в автомате МТ не существует (его роль может выполнять сток), допуск происходит при попадании в состояние .Сформируем последовательности и по МТ и строке ., ; для всех символов алфавита ленты (за исключением пробела):, , а также , ; для всех правил вида и для всех символов алфавита :, ; для всех правил вида :, ; для всех правил вида :, . Такие последовательности позволяют сформировать строки (из ) и (из ), но решения МПСП быть не может, так как все члены последовательностей, кроме первого, имеют равную длину, и строка, составленная из элементов , всегда оказывается длиннее.Задача — получить равные строки, если состояние достижимо. Для этого добавим в уже имеющиеся последовательности следующие элементы:для всех символов алфавита ленты (за исключением пробела):, , , , а также , . С помощью новых элементов можно привести обе строки к виду но только тогда, когда в , содержится ; другими словами, только тогда, когда автомат, принадлежащий , допускает . Таким образом, выполнено успешное m-сведение множества пар из машины Тьюринга (МТ) и строки , где не зависает, к множеству решений МПСП. |
Пример
Пусть автомат МТ состоит из двух состояний
и , алфавит ленты содержит символы и . Переходы автомата устроены следующим образом:;
;
из
переходов нет.Последовательности при строке
будут сформированы следующим образом:Номер элемента | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
Последовательность a | |||||||||||
Последовательность b |
Теорема: | |||||
ПСП неразрешима. | |||||
Доказательство: | |||||
Выполним m-сведение множества решений МПСП к множеству решений ПСП. Пусть даны последовательности из условия МПСП. Обозначим как и строки, состоящие из символов , разделённых : , .Построим две новые последовательности :
где , — символы, не встречающиеся в словах исходных последовательностей.
| |||||
Литература
- Джон Хопкрофт, Раджив Мотвани, Джеффри Ульман. Введение в теорию автоматов, языков и вычислений.