Теорема Ладнера — различия между версиями
Shevchen (обсуждение | вклад) м |
Kirelagin (обсуждение | вклад) |
||
Строка 68: | Строка 68: | ||
Вычисление значения <tex>g(n+1)</tex> состоит из вычисления <tex>g(n)</tex>, проверки неравенства <tex>(\log_2 n)^{g(n)} \ge n</tex> и, возможно, запуска одной из двух внутренних функций. Время выполнения этих функций составляет: | Вычисление значения <tex>g(n+1)</tex> состоит из вычисления <tex>g(n)</tex>, проверки неравенства <tex>(\log_2 n)^{g(n)} \ge n</tex> и, возможно, запуска одной из двух внутренних функций. Время выполнения этих функций составляет: | ||
− | + | <ul> | |
+ | <li>для случая <tex>g(n) \equiv 0 \pmod{2}</tex>:<br/> | ||
+ | <tex>\parbox{0px}{ | ||
+ | \begin{align*} | ||
+ | T(n) & \le 2^{\log_2 n} (T(M_i, x) + T(g, |x|) + T(x \in \mathrm{SAT})) \le \\ | ||
+ | & \le k_1 n (|x|^i + T(g, |x|) + 2^{|x|}|x|) \le \\ | ||
+ | & \le k_1 n ((\log_2 n)^{g(n)} + T(g, \log_2 n) + 2^{\log_2 n} \log_2 n) \le \\ | ||
+ | & \le k_1 (n^2 + n^2 \log_2 n + n T(g, \log_2 n)) \le \\ | ||
+ | & \le k_1 (2n^3 + n T(g, \log_2 n)) | ||
+ | \end{align*} | ||
+ | }</tex>; | ||
+ | </li> | ||
− | < | + | <li>для случая <tex>g(n) \equiv 1 \pmod{2}</tex>:<br/> |
− | + | <tex>\parbox{0px}{ | |
− | + | \begin{align*} | |
− | + | T(n) & \le 2^{\log_2 n} (T(x \in \mathrm{SAT}) + T(g, |f_i(x)|) + T(f_i(x) \in \mathrm{SAT})) \le \\ | |
− | + | & \le k_2 n (2^{\log_2 n} \log_2 n + T(g, \log_2 n) + 2^{\log_2 n} \log_2 n) \le \\ | |
− | + | & \le k_2 (2n^2 \log_2 n + n T(g, \log_2 n)) \le \\ | |
− | + | & \le k_2 (2n^3 + n T(g, \log_2 n)) | |
− | + | \end{align*} | |
− | <tex> | + | }</tex>. |
− | + | </li> | |
− | + | </ul> | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
Вычислить <tex>(\log_2 n)^{g(n)}</tex> можно за | Вычислить <tex>(\log_2 n)^{g(n)}</tex> можно за | ||
− | |||
<tex>k_3 \log_2 g(n) |(\log_2 n)^{g(n)}|^2 \le k_3 (g(n) |log_2 n|)^2 log_2 n \le k_3 n^3</tex>. | <tex>k_3 \log_2 g(n) |(\log_2 n)^{g(n)}|^2 \le k_3 (g(n) |log_2 n|)^2 log_2 n \le k_3 n^3</tex>. | ||
Таким образом, | Таким образом, | ||
− | |||
<tex>T(g, n) \le T(g, n-1) + k (n^3 + n T(g, \log_2 n))</tex>. | <tex>T(g, n) \le T(g, n-1) + k (n^3 + n T(g, \log_2 n))</tex>. | ||
Пусть <tex>T(g, 1) = d</tex>. Существует константа <tex>c \ge d</tex>, для которой при любом <tex>n</tex> верно | Пусть <tex>T(g, 1) = d</tex>. Существует константа <tex>c \ge d</tex>, для которой при любом <tex>n</tex> верно | ||
− | |||
<tex>c (n-1)^4 + k n^3 + k n c (\log_2 n)^4 \le c n^4</tex>. | <tex>c (n-1)^4 + k n^3 + k n c (\log_2 n)^4 \le c n^4</tex>. | ||
Версия 16:02, 3 июня 2012
Теорема Ладнера (Ladner's Theorem) утверждает, что если P не совпадает с NP, то существует язык, принадлежащий , но не являющийся ни полиномиальным, ни NP-полным.
Теорема (Ладнер): |
Доказательство: |
Предположим, что SAT) нельзя свести по Карпу к полиномиальному. Будем искать такой язык , чтобы язык удовлетворял следующим условиям: . Из этого следует, что никакой -полный язык (например,
Если выполнены все три свойства, то .Пусть — все машины Тьюринга из (возможно, с повторениями), расположенные в таком порядке, чтобы для любого .Пусть — аналогичное множество полиномиальных функций: для любого .Для простоты будем считать, что . Построим такую неубывающую функцию , что при для выполняются три перечисленных свойства.Алгоритм построения gПоложим . Для построим рекурсивно — с помощью .
for: if and or return if and and return
for: if and or return if and and return Корректность алгоритмаПроверим выполнение второго и третьего свойств языка .
Таким образом, при верности предположения второе и третье свойства выполнены.Время работы алгоритмаПроверим выполнение первого свойства языка . Для этого достаточно установить полиномиальность .Заметим, что по построению для .Вычисление значения состоит из вычисления , проверки неравенства и, возможно, запуска одной из двух внутренних функций. Время выполнения этих функций составляет:
Вычислить можно за .Таким образом, .Пусть Тогда, в силу . Существует константа , для которой при любом верно . и неравенства выше, по индукции легко доказать, что ограничено сверху , то есть , а, в свою очередь, . |
Источник
- William Gasarch, Lance Fortnow. Two Proofs of Ladner’s Theorem