Примеры NP-полных языков. Теорема Кука — различия между версиями
(→Ссылки) |
|||
Строка 51: | Строка 51: | ||
== Ссылки == | == Ссылки == | ||
* [[Класс P]] | * [[Класс P]] | ||
− | * [[ | + | * [[Классы NP и Σ₁]] |
* [[Сведение относительно класса функций. Сведение по Карпу. Трудные и полные задачи]] | * [[Сведение относительно класса функций. Сведение по Карпу. Трудные и полные задачи]] | ||
[[Категория: Теория сложности]] | [[Категория: Теория сложности]] |
Версия 16:47, 4 июня 2012
Эта статья находится в разработке!
Содержание
Введение
В этой статье мы рассмотрим класс NP-полных языков — NPC. NPC является одним из важнейших классов в теории сложности, так как если найдется язык из этого класса, который также входит в класс P, тогда окажется, что P = NP.
Мы рассмотрим некоторые языки и докажем их NP-полноту. Начнем мы с языка сведений по Карпу будем сводить уже известные языки из NPC к новым языкам, тем самым доказывая их NP-трудность, а потом и NP-полноту. Доказательство NP-полноты будет состоять из двух пунктов: доказательство NP-трудности и принадлежности языка классу NP.
, так как к нему несложно сводятся все языки из NP. Потом с помощьюNP-полнота
— язык троек , таких что недетерминированная машина Тьюринга на входной строке возращает 1 за время .
— недерминированная машина Тьюринга,
Теорема: |
Доказательство: |
|
NP-полнота
— язык булевых формул из переменных, для которых существует подстановка, при которой формула истинна.
Теорема (Кук): |
Доказательство: |
for : = choose ; if == 1: return 1 else return 0 |