Сведение по Карпу — различия между версиями
(→Пример) |
(→Определение) |
||
Строка 1: | Строка 1: | ||
==Определение== | ==Определение== | ||
− | Язык < | + | Язык <tex>A</tex> сводится по Карпу к языку <tex>B</tex>, если существует функция <tex>f(x)</tex> такая, что <tex>x \in A</tex> тогда и только тогда, когда <tex>f(x) \in B</tex>. |
Обычно требуют, чтобы сводящая функция была вычислима за полиномиальное время от длины входа. | Обычно требуют, чтобы сводящая функция была вычислима за полиномиальное время от длины входа. | ||
+ | |||
+ | Заметим, что в таком случае класс языков P замкнут относительно сведения по Карпу, т.к. сводящая функция может решить сводимую задачу за полиномиальное время от длины входа и выдать нужный результат. | ||
==Пример== | ==Пример== |
Версия 20:45, 14 марта 2010
Содержание
Определение
Язык
сводится по Карпу к языку , если существует функция такая, что тогда и только тогда, когда .Обычно требуют, чтобы сводящая функция была вычислима за полиномиальное время от длины входа.
Заметим, что в таком случае класс языков P замкнут относительно сведения по Карпу, т.к. сводящая функция может решить сводимую задачу за полиномиальное время от длины входа и выдать нужный результат.
Пример
Рассмотрим следующие языки:
и — множества пар , где — граф, — натуральное число. Пара принадлежит , если в графе есть подграф с вершинами, в котором все вершины не связаны ребрами. Пара принадлежит , если в графе есть подграф с вершинами, в котором между каждой парой вершин проходит ребро.Существует функция
такая, что , где — граф, в котором столько же вершин, сколько и в , а ребра расставлены следующим образом: если в графе между вершинами и есть ребро, то в графе это ребро не проводится, если же в графе между этими вершинами его не было, то в оно есть между соответствующими вершинами. Эта функция вычисляется за линейное время от длины входа, если представлять граф в виде матрицы смежности.Заметим, что если в графе
был независимый подграф с вершинами, то в между всеми вершинами подграфа будут ребра, следовательно, в графе будет клика с вершинами.С другой стороны, если в
есть клика с вершинами, значит между всеми вершинами клики проведены ребра, а значит их не было в графе . Т.о. в графе был независимый подграф с вершинами.Из всего сказанного следует, что
.Теорема
Операция сведения по Карпу транзитивна. Т.е. если
, , то .Доказательство
Пусть
. Тогда существует функция : . Пусть в свою очередь и есть функция : .Рассмотрим функция
. . Также . Т.е. . Проверим, что функция вычислима за полиномиальное время от длины входа. Для вычисления значения функции сначала нужно вычислить . Время вычисления ограничено сверху некоторым полиномом , т.к. эта функция применяется в сведении по Карпу. Затем нужно вычислить . Пусть . Т.к. за единицу времени может быть написан лишь один символ, то . Время вычисления ограничено сверху некоторым полиномом . Т.о. время вычисления не больше <tex>p_2(p_1(|x|)) + p_1(|x|)<tex>.