NP-полнота задачи о выполнимости булевой формулы в форме 3-КНФ — различия между версиями
Строка 9: | Строка 9: | ||
# <tex> 3SAT \in NPH </tex>; | # <tex> 3SAT \in NPH </tex>; | ||
− | |||
− | |||
− | + | Для того, чтобы доказать первый факт, предъявим сертификат: набор <tex>x_1 \ldots x_{n}</tex>, удовлетворяющий формулу. | |
+ | |||
Теперь докажем <tex>NP</tex>-трудность <tex>3SAT</tex>. | Теперь докажем <tex>NP</tex>-трудность <tex>3SAT</tex>. | ||
Для этого покажем, что <tex>CNFSAT \le 3SAT</tex>, то есть <tex>CNFSAT</tex> сводится по Куку к <tex>3SAT</tex>. | Для этого покажем, что <tex>CNFSAT \le 3SAT</tex>, то есть <tex>CNFSAT</tex> сводится по Куку к <tex>3SAT</tex>. |
Версия 17:27, 16 марта 2010
Теорема
, т.е. задача о выполнимости булевой формулы в форме 3-КНФ -полна.
Доказательство
Для того, чтобы доказать
-полноту задачи, необходимо установить следующие факты:- .
- ;
Для того, чтобы доказать первый факт, предъявим сертификат: набор , удовлетворяющий формулу.
Теперь докажем
-трудность . Для этого покажем, что , то есть сводится по Куку к .Рассмотрим один член булевой формулы в форме КНФ (скобку). В форме 3-КНФ этот член должен иметь вид
. Научимся приводить члены вида , , к нужному виду.- заменим на . Ясно, что последняя формула выполнима тогда и только тогда, когда выполнима исходная, при любых ;
- заменим на - свели задачу к предыдущей;