|
|
Строка 32: |
Строка 32: |
| |statement=Сведение по Карпу транзитивно, то есть: <tex> ( L_1 \leq L_2, L_2 \leq L_3 ) \Rightarrow L_1 \leq L_3 </tex>. | | |statement=Сведение по Карпу транзитивно, то есть: <tex> ( L_1 \leq L_2, L_2 \leq L_3 ) \Rightarrow L_1 \leq L_3 </tex>. |
| |proof= | | |proof= |
− | Пусть <tex>f</tex> и <tex>g</tex> — функции из определения сведения для <tex> L_1 \leq L_2 </tex> и <tex> L_2 \leq L_3 </tex> соответственно. Из определения следует: <tex>x \in L_1 \Leftrightarrow f(x) \in L_2 \Leftrightarrow g(f(x)) \in L_3</tex>.<br> | + | Пусть <tex>f</tex> и <tex>g</tex> — функции из определения сведения для <tex> L_1 \leq L_2 </tex> и <tex> L_2 \leq L_3 </tex> соответственно. Из определения следует: <tex>x \in L_1 \Leftrightarrow f(x) \in L_2 \Leftrightarrow g(f(x)) \in L_3</tex>. |
− | Проверим, что <tex>g(f(x))</tex> вычислима за полиномиальное время от <tex>|x|</tex>. В самом деле, сначала нужно вычислить <tex>f(x)</tex>, на это необходимо полиномиальное время. Более того, длина входа <tex>g</tex> в <tex>g(f(x))</tex> тоже полиномиальна, так как за единицу времени может быть выведено не более, чем константное число символов. Значит, вычисление <tex>g</tex> на <tex>f(x)</tex> займёт времени не более, чем полином. | + | |
− | В итоге получаем, что итоговое время работы <tex>g(f(x))</tex> полиномиально от <tex>|x|</tex>.
| + | Проверим, что <tex>g(f(x))</tex> вычислима за полиномиальное от <tex>|x|</tex> время.<br/> |
| + | Действительно, первым делом необходимо вычислить <tex>f(x)</tex>, на это уйдет полином от <tex>|x|</tex> времени.<br/> |
| + | Кроме того, длина входа <tex>g</tex>, являющегося выводом <tex>f(x)</tex>, тоже полиномиальна, так как за единицу времени может быть выведено не более, чем константное число символов. Значит, вычисление <tex>g(f(x))</tex> также займет времени не более, чем полином от <tex>|x|</tex>. |
| + | |
| + | Таким образом, полное время работы программы есть сумма полиномов от <tex>|x|</tex> и потому тоже является полиномом от <tex>|x|</tex>. |
| }} | | }} |
| | | |
Версия 22:50, 11 мая 2012
Определения
Определение: |
[math]D[/math] — класс языков, удовлетворяющих некоторым ограничениям; [math]\widetilde{D}[/math] — класс вычислимых функций, удовлетворяющих тем же ограничениям.
Язык [math]L_1[/math] сводится к языку [math]L_2[/math] относительно [math]\widetilde{D}[/math] ([math]L_1 \leq_{\widetilde{D}} L_2[/math]), если существует такая функция [math]f[/math] из [math]\widetilde{D}[/math], что [math]x[/math] принадлежит [math]L_1[/math] тогда и только тогда, когда [math]f(x)[/math] принадлежит [math]L_2[/math]:
[math] (L_1 \leq_{\widetilde{D}} L_2) \overset{\underset{\mathrm{def}}{}}{\iff} ( \exists f \in \widetilde{D} : x \in L_1 \Leftrightarrow f(x) \in L_2 ) [/math]. |
Определение: |
Сведение относительно [math]\widetilde{P}[/math] называется сведением по Карпу. |
Замечание. Часто используется именно сведение по Карпу, поэтому слова «относительно сведения по Карпу» и индекс у символа сведения обычно опускают.
Простой пример сведения по Карпу
Зададим следующие языки:
- [math]IND[/math] — множество пар вида [math] \langle G, k \rangle [/math], где [math]G[/math] — граф, а [math]k[/math] — число, такое, что в [math]G[/math] есть независимое множество размера [math]k[/math].
- [math]CLIQUE[/math] — множество пар вида [math] \langle G, k \rangle [/math], где [math]G[/math] — граф, а [math]k[/math] — число, такое, что в [math]G[/math] есть клика размера [math]k[/math].
Теорема: |
[math]IND \leq CLIQUE[/math] |
Доказательство: |
[math]\triangleright[/math] |
Рассмотрим функцию [math]f( \langle G, k \rangle ) = \langle \overline{G}, k \rangle[/math], где [math]\overline{G}[/math] — дополнение графа [math]G[/math]. [math]f[/math] вычислима за линейное время от длины входа, если граф задан в виде матрицы смежности.
- ([math]x \in L_1 \Rightarrow f(x) \in L_2[/math]). Заметим, что, если в [math]G[/math] было независимое множество размера [math]k[/math], то в [math]\overline{G}[/math] будет клика такого же размера (вершины, которые были в независимом множестве, в [math]\overline{G}[/math] попарно соединены рёбрами и образуют клику).
- ([math]x \in L_1 \Leftarrow f(x) \in L_2[/math]). Обратно, если в [math]\overline{G}[/math] есть клика размера [math]k[/math], то в исходном графе было независимое множество размера [math]k[/math].
Таким образом, [math]IND \leq CLIQUE[/math] по определению. |
[math]\triangleleft[/math] |
Замечание. Другие примеры сведения по Карпу приведены в статье, содержащей примеры NP-полных языков.
Свойства сведения
Теорема (о транзитивности): |
Сведение по Карпу транзитивно, то есть: [math] ( L_1 \leq L_2, L_2 \leq L_3 ) \Rightarrow L_1 \leq L_3 [/math]. |
Доказательство: |
[math]\triangleright[/math] |
Пусть [math]f[/math] и [math]g[/math] — функции из определения сведения для [math] L_1 \leq L_2 [/math] и [math] L_2 \leq L_3 [/math] соответственно. Из определения следует: [math]x \in L_1 \Leftrightarrow f(x) \in L_2 \Leftrightarrow g(f(x)) \in L_3[/math].
Проверим, что [math]g(f(x))[/math] вычислима за полиномиальное от [math]|x|[/math] время.
Действительно, первым делом необходимо вычислить [math]f(x)[/math], на это уйдет полином от [math]|x|[/math] времени.
Кроме того, длина входа [math]g[/math], являющегося выводом [math]f(x)[/math], тоже полиномиальна, так как за единицу времени может быть выведено не более, чем константное число символов. Значит, вычисление [math]g(f(x))[/math] также займет времени не более, чем полином от [math]|x|[/math].
Таким образом, полное время работы программы есть сумма полиномов от [math]|x|[/math] и потому тоже является полиномом от [math]|x|[/math]. |
[math]\triangleleft[/math] |
Лемма: |
[math](L_1 \leq_{\widetilde{D}} L_2) \Leftrightarrow (\overline {L_1} \leq_{\widetilde{D}} \overline {L_2})[/math] |
Доказательство: |
[math]\triangleright[/math] |
По определению сведения существует такая функция [math]f[/math] из класса [math]\widetilde{D}[/math], что [math]x \in L_1 \Leftrightarrow f(x) \in L_2[/math]. Для того, чтобы свести [math]\overline{L_1}[/math] к [math]\overline{L_2}[/math] будем использовать ту же функцию [math]f[/math].
В самом деле: [math]( x \in L_1 \Leftrightarrow f(x) \in L_2 ) \iff ( \overline{x \in L_1} \Leftrightarrow \overline{f(x) \in L_2} ) [/math] [math]\iff ( x \in \overline{L_1} \Leftrightarrow f(x) \in \overline{L_2} ) \iff (\overline {L_1} \leq_{\widetilde{D}} \overline {L_2})[/math]. |
[math]\triangleleft[/math] |
Определения трудных и сложных задач
Определение: |
[math]C[/math] — сложностный класс, [math]\widetilde{D}[/math] — класс вычислимых функций. Язык [math]L[/math] называется [math]C[/math]-трудным относительно [math]\widetilde{D}[/math]-сведения ([math]C[/math]-hard), если любой язык [math]M[/math] из [math]C[/math] сводится к [math]L[/math] относительно [math]\widetilde{D}[/math]:
[math] (L [/math] — [math]C[/math]-hard [math]) \overset{\underset{\mathrm{def}}{}}{\Leftrightarrow} ( \forall M \in C \Rightarrow M \leq_{f} L, f \in \widetilde{D} ) [/math]. |
Определение: |
[math]C[/math] — сложностный класс, [math]\widetilde{D}[/math] — класс вычислимых функций. Язык [math]L[/math] называется [math]C[/math]-полным относительно [math]\widetilde{D}[/math]-сведения ([math]C[/math]-complete), если [math]L[/math] является [math]C[/math]-трудным относительно [math]\widetilde{D}[/math]-сведения и сам лежит в [math]C[/math]. |