Сведение относительно класса функций. Сведение по Карпу. Трудные и полные задачи — различия между версиями
Leugenea (обсуждение | вклад) (Добавил определение сложного языка) |
Leugenea (обсуждение | вклад) (Определение полного языка) |
||
| Строка 33: | Строка 33: | ||
<tex> (L </tex> — <tex>C</tex>-hard <tex>) \Leftrightarrow ( \forall M \in C \Rightarrow M \leq_{f} L, f \in \widetilde{D} ) </tex>. | <tex> (L </tex> — <tex>C</tex>-hard <tex>) \Leftrightarrow ( \forall M \in C \Rightarrow M \leq_{f} L, f \in \widetilde{D} ) </tex>. | ||
}} | }} | ||
| + | |||
| + | {{Определение | ||
| + | |definition = | ||
| + | <tex>C</tex> — сложностный класс, <tex>\widetilde{D}</tex> — сведение. Язык <tex>L</tex> называется '''<tex>C</tex>-полным относительно сведения <tex>\widetilde{D}</tex> (<tex>C</tex>-complete)''', если <tex>L</tex> является <tex>C</tex>-трудным относительно сведения <tex>\widetilde{D}</tex> и сам лежит в <tex>C</tex>. | ||
| + | }} | ||
| + | |||
| + | '''Замечание.''' Часто используется сведение по Карпу, поэтому слова «относительно сведения по Карпу» обычно опускаются. Например, [[Примеры NP-полных языков. Теорема Кука | NP-полные языки]]. | ||
Версия 22:38, 15 апреля 2012
| Определение: |
| Язык сводится по Карпу к языку (), если существует такая функция , вычислимая за полиномиальное от длины входа время, что принадлежит тогда и только тогда, когда принадлежит : . |
Банальный пример сведения по Карпу
Зададим следующие языки:
- — множество пар вида , где — граф, а — число, таких, что в есть независимое множество размера .
- — множество пар вида , где — граф, а — опять же, число, таких, что в есть клика размера .
Докажем, что .
Рассмотрим функцию , где — дополнение графа . вычислима за линейное время от длины входа, если граф представлен в видел матрицы смежности.
- () Заметим, что если в было независимое множество размера , то в будет клика такого же размера (вершины, которые были в независимом множестве, в попарно соединены рёбрами и образуют клику).
- () Обратно, если в есть клика размера , то в исходном графе было независимое множество размера .
Таким образом, по определению.
Замечание. Многие другие примеры сведения по Карпу могут быть найдены в статье про примеры NP-полных языков.
| Теорема (о транзитивности): |
Сведение по Карпу транзитивно, то есть: . |
| Доказательство: |
|
Пусть и — функции из определения сведения для и соответственно. Из определения следует: . |
| Определение: |
| — сложностный класс, — сведение. Язык называется -трудным относительно сведения (-hard), если любой язык из сводится по к : — -hard . |
| Определение: |
| — сложностный класс, — сведение. Язык называется -полным относительно сведения (-complete), если является -трудным относительно сведения и сам лежит в . |
Замечание. Часто используется сведение по Карпу, поэтому слова «относительно сведения по Карпу» обычно опускаются. Например, NP-полные языки.