NP-полнота задачи о раскраске графа
НЕТ ВОЙНЕ |
24 февраля 2022 года российское руководство во главе с Владимиром Путиным развязало агрессивную войну против Украины. В глазах всего мира это военное преступление совершено от лица всей страны, всех россиян. Будучи гражданами Российской Федерации, мы против своей воли оказались ответственными за нарушение международного права, военное вторжение и массовую гибель людей. Чудовищность совершенного преступления не оставляет возможности промолчать или ограничиться пассивным несогласием. Мы убеждены в абсолютной ценности человеческой жизни, в незыблемости прав и свобод личности. Режим Путина — угроза этим ценностям. Наша задача — обьединить все силы для сопротивления ей. Эту войну начали не россияне, а обезумевший диктатор. И наш гражданский долг — сделать всё, чтобы её остановить. Антивоенный комитет России |
Распространяйте правду о текущих событиях, оберегайте от пропаганды своих друзей и близких. Изменение общественного восприятия войны - ключ к её завершению. |
meduza.io, Популярная политика, Новая газета, zona.media, Майкл Наки. |
Содержание
Формулировка задачи
Даны граф
и число . Необходимо проверить, правда ли, что можно раскрасить вершины графа в цветов так, чтобы любые две вершины, соединённые ребром, имели разные цвета.Утверждение
Сформулированная выше задача NP-полна.
Доказательство
Доказательство принадлежности задачи классу NP
Сертификатом для решения данной задачи будет последовательность
, где , а обозначает цвет -ой вершины. Проверку корректности такого сертификата легко осуществить за полиномиальное время, например, перебором всех пар вершин и проверкой того, что в случае, когда они соединены ребром, они имеют разные цвета, лежащие на отрезке . С другой стороны, очевидно, что если задача имеет решение, то такой сертификат существует.Доказательство принадлежности задачи классу NPH
Сведем задачу 3CNFSAT к данной.
Пусть дана формула , где , и — переменные или их отрицания (возможно, с повторениями). Сами переменные будем обозначать .
Заметим следующие тривиальные факты, которые будут использованы при построении графа:
- Ровно одно выражение из истинно;
- тогда и только тогда, когда существует набор, обращающий каждую скобку в истину.
Построим множества V и E будущего графа следующим образом:
- ;
- .
Будем интерпретировать
как цвет (соотвественно, вершина всегда покрашена в цвет ), причем — цвет, обозначающий истину, а все остальные цвета означают ложь).- Для всех добавим в V вершины , отвечающие и соответственно, и соединим каждую такую пару ребром;
- Каждую вершину из соединим рёбрами со всеми , кроме и .
Этим мы обеспечили выполнение первого условия из приведённых выше, так как теперь ровно одна вершина из
Осталось сделать так, чтобы возможность сделать истинной каждую скобку соответствовала необходимости покрасить хотя бы одну из вершин, соответствующих переменным в ней, в цвет .
- Для этого для каждой скобки вида
Доказательство корректности сведения
Покажем теперь, что такой граф будет
-раскрашиваемым тогда и только тогда, когда исходная формула принадлежит .- . Из построения ясно, что можно покрасить вершины полученного графа, соответствующие истинным термам набора, обращающего формулу в истину, в цвет , а вершины, соответствующие ложным термам, — в соответствующие "ложные" цвета.
- . Построим по раскраске графа набор переменных , в котором истинно тогда и только тогда, когда покрашена в цвет . Этот набор непротиворечив (мы не попытались одну и ту же переменную сделать и истинной, и ложной одновременно). Он также обращает формулу в истинную, так как по постронию в каждой скобке есть хотя бы один истинный терм.