NP-полнота задачи о выполнимости булевой формулы в форме 3-КНФ — различия между версиями
(→Доказательство принадлежности 3SAT классу NPH) |
(→Доказательство принадлежности 3SAT классу NPH) |
||
Строка 34: | Строка 34: | ||
Докажем эти утверждения. Пусть все новые дизъюнкты удовлетворяются некоторым набором значений <tex>x_i</tex> и <tex>z_i</tex>. Покажем, что тогда хотя бы один из <tex>x_i</tex> должен равняться <tex>true</tex>. | Докажем эти утверждения. Пусть все новые дизъюнкты удовлетворяются некоторым набором значений <tex>x_i</tex> и <tex>z_i</tex>. Покажем, что тогда хотя бы один из <tex>x_i</tex> должен равняться <tex>true</tex>. | ||
− | Предположим, что это не так, и <tex>x_i = false, | + | Предположим, что это не так, и <tex>x_i = false, i = 1..k</tex>. Тогда, первые <tex>k-3</tex> дизъюнкта в <tex>3SAT</tex> только если <tex>z_i = true, i=1..k-3</tex>. Однако, если <tex>z_{k-3}=true</tex>, то последний дизъюнкт <tex>(x_{k-1} \vee x_k \vee \neg z_{k-3})</tex> не можут быть удовлетворен. |
Таким образом, мы свели <tex>CNFSAT</tex> к <tex>3SAT</TEX>, следовательно <tex>3SAT \in NPH</tex>. Теорема доказана. | Таким образом, мы свели <tex>CNFSAT</tex> к <tex>3SAT</TEX>, следовательно <tex>3SAT \in NPH</tex>. Теорема доказана. |
Версия 15:04, 19 марта 2010
Содержание
Задача
в 3-КНФ,
Теорема
Доказательство
Для того, чтобы доказать NP-полноту задачи, необходимо установить следующие факты:
- .
- ;
Доказательство принадлежности 3SAT классу NP
Возьмем в качестве сертификата набор
, где . Верификатор подставляет в формулу и проверяет её на равенство единице. Время работы верификатора и длина сертификата, очевидно, полиномиальны. Итак, .Доказательство принадлежности 3SAT классу NPH
Покажем, что сводится по Куку к .
, то естьРассмотрим один дизъюнкт булевой формулы в форме 3-КНФ. Он должен иметь вид . Научимся приводить члены вида , , к нужному виду.
- заменим на . Ясно, что последняя формула выполнима тогда и только тогда, когда выполнима исходная, при любых ;
- заменим на - свели задачу к предыдущей;
- Если встречается дизъюнкт вида , введем новых переменных и заменим наш дизъюнкт на дизъюнкта: . Покажем, что эта замена корректна.
Для этого, сделаем несколько утверждений:
- Если - набор значений , удовлетворяющий дизъюнкт , то существует такой набор значений , что каждый из новых дизъюнктов также удовлетворен.
- Среди значений хотя бы одно должно равняться . Не умаляя общности, пусть для некоторого . Тогда, пусть для и для . Тогда, все новые дизъюнкты также будут удовлетворены.
Докажем эти утверждения. Пусть все новые дизъюнкты удовлетворяются некоторым набором значений
и . Покажем, что тогда хотя бы один из должен равняться .Предположим, что это не так, и
. Тогда, первые дизъюнкта в только если . Однако, если , то последний дизъюнкт не можут быть удовлетворен.Таким образом, мы свели
к , следовательно . Теорема доказана.