Примеры NP-полных языков. Теорема Кука — различия между версиями
м |
|||
Строка 34: | Строка 34: | ||
<tex>p(\varphi)</tex> | <tex>p(\varphi)</tex> | ||
for <tex> i \in \lbrace 1 \ldots n \rbrace </tex>: | for <tex> i \in \lbrace 1 \ldots n \rbrace </tex>: | ||
− | <tex> x_i </tex> = | + | <tex> x_i </tex> = choose<tex> \lbrace 0, 1 \rbrace </tex>; |
if <tex> \varphi(x) </tex> == 1: | if <tex> \varphi(x) </tex> == 1: | ||
return 1 | return 1 |
Версия 15:39, 4 июня 2012
Эта статья находится в разработке!
Содержание
Введение
В этой статье мы рассмотрим класс NP-полных языков — NPC. NPC является одним из важнейших классов в теории сложности, так как если найдется язык из этого класса, который также входит в класс P, тогда окажется, что P = NP.
Мы рассмотрим некоторые языки и докажем их NP-полноту. Начнем мы с языка
, так как к нему несложно сводятся все языки из NP. Потом с помощью сведений по Карпу будем сводить уже известные языки из NPC к новым языкам, тем самым доказывая их NP-трудность, а потом и NP-полноту. Доказательство NP-полноты будет состоять из двух пунктов: доказательство NP-трудности и принадлежности языка классу NP.NP-полнота
— язык троек , таких что недетерминированная машина Тьюринга на входной строке возращает 1 за время .
— недерминированная машина Тьюринга,
Теорема: |
Доказательство: |
|
NP-полнота
— язык булевых формул из переменных, для которых существует подстановка, при которой формула истинна.
Теорема (Кук): |
Доказательство: |
for : = choose ; if == 1: return 1 else return 0 |