Специальные формы КНФ — различия между версиями
Nemzs (обсуждение | вклад) (→Разрешимать булевой формулы, заданой в форме Крома) |
Nemzs (обсуждение | вклад) (→Разрешимость булевой формулы, заданой в форме Крома) |
||
Строка 16: | Строка 16: | ||
{{Утверждение | {{Утверждение | ||
− | |statement=Функцию <tex>F</tex> можно задать в форме Крома <tex> \iff </tex> выполнено следующее следствие:<tex> F(x_1, ..., x_n)=F(y_1, ..., y_n)=F(z_1, ..., z_n)=1 \Rightarrow</tex> <tex>F(\langle x_1, y_1, z_1 \rangle, \langle x_2, y_2, z_2 \rangle, ..., \langle x_n, y_n, z_n \rangle)</tex> | + | |statement=Функцию <tex>F</tex> можно задать в форме Крома <tex> \iff </tex> выполнено следующее следствие : <tex> F(x_1, ..., x_n)=F(y_1, ..., y_n)=F(z_1, ..., z_n)=1 \Rightarrow</tex> <tex>F(\langle x_1, y_1, z_1 \rangle, \langle x_2, y_2, z_2 \rangle, ..., \langle x_n, y_n, z_n \rangle)</tex> |
}} | }} | ||
Версия 00:34, 17 июня 2016
Рассмотрим две формы, с помощью которых можно представить формулы, заданные в конъюнктивной нормальной форме, то есть имеющей вид конъюнкции выражений в скобках, каждое из которых представляет собой дизъюнкцию одного или нескольких литералов. Эти две формы интересны тем, что для них существует алгоритм, который может за полиномиальное время проверить, существует ли набор аргументов, на которых данная функция будет принимать значение , в то время, как для обычной функции, не представленной данной формой, эта задача является NP-полной.
Содержание
КНФ в форме Крома
Определение: |
Конъюнктивная нормальная форма (КНФ) в форме Крома (2-КНФ) (англ. 2-CNF) — это конъюнкция выражений в скобках, каждое из которых представляет собой дизъюнкцию нескольких литералов, количество которых не превышает двух. |
Пример :
Разрешимость булевой формулы, заданой в форме Крома
Утверждение: |
Функцию можно задать в форме Крома выполнено следующее следствие : |
КНФ в форме Хорна
Определение: |
Конъюнктивная нормальная форма (КНФ)в форме Хорна (англ. Horn clause) — это конъюнкция выражений в скобках, каждое из которых представляет собой дизъюнкцию литералов, в которой присутствует не более одного литерала без отрицания. |
Пример:
Каждая скобка представляет собой Дизъюнкт Хорна[1].
Любую формулу можно представить в виде КНФ в форме Хорна. Для этого формулу необходимо преобразовать в конъюнкцию элементарных дизъюнкций и далее каждую дизъюнкцию представить в форме дизьюнкта Хорна.
Утверждение: |
Существует алгоритм, который за полиномиальное время проверяет, что функцию, заданную в форме Хорна можно удовлетворить. |
Далее будет приведено доказательство, предлагающее алгоритм решения. Представление функции Функцию можно представить в любом виде. Например, можно использовать древовидную структуру.
Так как функция состоит из простых выражений, мы сможем её разбить на дерево за линейное время. Будем считать, что длиной формулы является количество переменных, входящих в нее. Обозначим ее за В каждом шаге алгоритма мы обрабатываем очередную одиночную переменную за линейное время. Отсюда следует, что время работы линейное, относительно количества входящих переменных. . |
Утверждение: |
Функцию можно задать в форме Хорна выполнено следующее следствие: |