Класс NP: различия между версиями
[отпатрулированная версия] | [непроверенная версия] |
м робот добавил: nl:NP (complexiteitsklasse) |
UNV (обсуждение | вклад) +перевод интуитивного определения из английской статьи |
||
Строка 1: | Строка 1: | ||
В [[теория алгоритмов|теории алгоритмов]] '''классом NP''' (от [[англ.]] ''non-deterministic polynomial'') называют множество [[алгоритм]]ов, время работы которых существенно зависит от размера входных данных; в то же время, если предоставить алгоритму некоторые дополнительные сведения (так называемых свидетелей решения), то он сможет достаточно быстро (за время, не превосходящее [[многочлен]]а от размера данных) решить задачу. |
В [[теория алгоритмов|теории алгоритмов]] '''классом NP''' (от [[англ.]] ''non-deterministic polynomial'') называют множество [[алгоритм]]ов, время работы которых существенно зависит от размера входных данных; в то же время, если предоставить алгоритму некоторые дополнительные сведения (так называемых свидетелей решения), то он сможет достаточно быстро (за время, не превосходящее [[многочлен]]а от размера данных) решить задачу. |
||
Интуитивно, класс NP объединяет задачи для которых сравнительно легко (за полиномиальное время и с помощью [[Детерминированная машина Тьюринга|детерминированной машины Тьюринга]]) можно доказать что предлагаемое решение действительно принадлежит множеству решений. Или, что эквивалентно, задачи NP-класса могут быть решены за полиномиальное время [[Недетерминированная машина Тьюринга|недетерминированной машиной Тьюринга]]. |
|||
== Формальное определение == |
== Формальное определение == |
Версия от 08:50, 16 марта 2010
В теории алгоритмов классом NP (от англ. non-deterministic polynomial) называют множество алгоритмов, время работы которых существенно зависит от размера входных данных; в то же время, если предоставить алгоритму некоторые дополнительные сведения (так называемых свидетелей решения), то он сможет достаточно быстро (за время, не превосходящее многочлена от размера данных) решить задачу.
Интуитивно, класс NP объединяет задачи для которых сравнительно легко (за полиномиальное время и с помощью детерминированной машины Тьюринга) можно доказать что предлагаемое решение действительно принадлежит множеству решений. Или, что эквивалентно, задачи NP-класса могут быть решены за полиномиальное время недетерминированной машиной Тьюринга.
Формальное определение
Класс сложности NP определяется для множества языков, т.е. множеств слов над конечным алфавитом . Язык L называется принадлежащим классу NP, если существуют двуместный предикат из класса P (т.е. вычислимый за полиномиальное время) и многочлен такие, что для всякого слова x условие «x принадлежит L» равносильно условию «найдётся y длины меньше такой, что верно » (где n — длина слова x). Слово y называется свидетелем принадлежности x языку L. Таким образом, если у нас есть слово, принадлежащее языку, и ещё одно слово-свидетель ограниченной длины (которое бывает трудно найти), то мы быстро сможем удостовериться в том, что x действительно принадлежит L.
Эквивалентное определение можно получить, используя понятие недетерминированной машины Тьюринга (т. е. обычной машины Тьюринга, у программы которой могут существовать разные строки с одинаковой левой частью). Если машина встретила «развилку», т. е. неоднозначность в программе, то дальше возможны разные варианты вычисления. Предикат , который представляет данная недетерминированная машина Тьюринга, считается равным единице, если существует хоть один вариант вычисления, возвращающий 1, и нулю, если все варианты возвращают 0. Если длина вычисления, дающего 1, не превосходит некоторого многочлена от длины x, то предикат называется принадлежащим классу NP. Если у языка существует распознающий его предикат из класса NP, то язык называется принадлежащим классу NP. Такое определение эквивалентно верхнему: в качестве свидетеля можно взять номера нужных веток при развилках в вычислении. Поскольку, если x принадлежит языку, длина всего пути вычисления не превосходит многочлена, то и длина свидетеля тоже будет не превосходить многочлена от длины x.
Всякую задачу, принадлежащую NP, можно решить за экспоненциальное время перебором всех возможных свидетелей длины меньше .
Легко видеть, что множество языков из NP не замкнуто относительно дополнения. Класс языков, дополнение которых принадлежит NP, называется классом co-NP.
Отношения класса NP с другими классами
Класс NP включает в себя класс P (даже точнее, известно включение ). Однако ничего не известно о строгости этого включения. Задача о равенстве классов P и NP является одной из центральных открытых проблем теории алгоритмов. Если они равны, то любую задачу из класса NP можно будет решить быстро (за полиномиальное время). Однако научное сообщество склоняется в сторону отрицательного ответа на этот вопрос.
Класс NP включается в другие, более широкие классы, например, в класс PH. Существуют также открытые вопросы о строгости его включения в другие классы.
Примеры задач класса NP
Можно привести много задач, про которые на сегодняшний день неизвестно, принадлежат ли они P, но известно, что они принадлежат NP. Среди них:
- Задача выполнимости булевых формул: узнать по данной булевой формуле, существует ли набор входящих в неё переменных, обращающий её в 1. Свидетель — такой набор.
- Задача о клике: по данному графу узнать, есть ли в нём клики (полные подграфы) данного размера. Свидетель — номера вершин, образующих клику.
- Проблема существования гамильтонова цикла в графе. Свидетель — последовательность вершин, образующих гамильтонов цикл.
- Задача о коммивояжёре — расширенный и более приближенный к реальности вариант предыдущей задачи.
- Существование целочисленного решения системы линейных неравенств. Свидетель — решение.
Среди всех задач класса NP можно выделить «самые сложные» — NP-полные задачи. Если мы научимся решать любую из них за полиномиальное время, то все задачи класса NP можно будет решить за полиномиальное время. (См. также список таких задач.)