Примеры неразрешимых задач: проблема соответствий Поста — различия между версиями
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-сведение множества решений МПСП к множеству решений ПСП. Пусть даны последовательности из условия МПСП. Обозначим как и строки, состоящие из символов , разделённых : , . Построим две новые последовательности :
где , — символы, не встречающиеся в словах исходных последовательностей.
| |||||
Литература
- Джон Хопкрофт, Раджив Мотвани, Джеффри Ульман. Введение в теорию автоматов, языков и вычислений.