Клас складності P

Клас складності P (англ. Complexity class P) — клас задач, що можна розв'язати алгоритмами з поліноміальним часом.

Формальне визначення

Алгоритмом з поліноміальним часом називається такий алгоритм, час роботи якого (тобто, кількість елементарних двійкових операцій, необхідних для його виконання на детермінованій машині Тюринга) на вхідному рядку довжиною l {\displaystyle l} обмежено згори деяким поліномом P ( l ) {\displaystyle P(l)} .[1]

Задачі, що можна розв'язати алгоритмом з поліноміальним часом належать до класу задач складності P.

Машини Тюринга

Докладніше: Машина Тюринга

Машина Тюринга M {\displaystyle M} має часову складність (або час роботи) T ( n ) {\displaystyle T(n)} , якщо для довільного входу w {\displaystyle w} довжини n {\displaystyle n} , не залежно від результату машина M {\displaystyle M} зупиниться після виконання щонайбільше T ( n ) {\displaystyle T(n)} кроків.

Деяка мова L {\displaystyle L} належить до класу складності P, якщо існує поліноміальне T ( n ) {\displaystyle T(n)} таке, що мова L {\displaystyle L} розпізнається деякою детермінованою машиною Тюринга M {\displaystyle M} ( L = L ( M ) {\displaystyle L=L(M)} ) з часовою складністю T ( n ) {\displaystyle T(n)} .[2]

Практичне значення

Оскільки часто доводиться обчислювати значення функцій на вхідних даних великого обсягу, знаходження поліноміальних алгоритмів для обчислення функцій є дуже важливим завданням. Вважається, що обчислювати функції, які не лежать у класі P {\displaystyle P} , помітно складніше, ніж лежать. Більшість алгоритмів, що лежать в класі P {\displaystyle P} , мають складність, яка не перевершує многочлен в невеликій мірі від розміру вхідних даних.

Вужче визначення

Іноді під класом P мають на увазі вужчий клас функцій, а саме клас предикатів (функцій f : Σ { 0 , 1 } {\displaystyle f:\Sigma ^{*}\to \{0,\,1\}} ). Тоді мова L {\displaystyle L} , що розпізнає даний предикат, називається множиною слів, де предикат дорівнює 1. Мовами класу P називаються мови, для яких існують розпізнавальні їх предикати класу P. Очевидно, якщо мови L 1 {\displaystyle L_{1}} і L 2 {\displaystyle L_{2}} лежать у класі P, то і їх об'єднання, перетин та доповнення також лежать в класі P[джерело?].

Включення класу P в інші класи

Клас P є одним з найвужчих класів складності. Алгоритми, що належать йому, належать також класу NP, класу BPP (як допускають поліноміальну реалізацію з нульовою помилкою), класу PSPACE (т. к. зона роботи на машині Тюрінга завжди менше часу), класу P/Poly (для доказу цього факту використовується поняття протоколу роботи машини, який переробляється в булеву схему поліноміального розміру)[джерело?].

Вже більше 30 років залишається невирішеною задача про рівність класів P і NP. Якщо вони рівні, то будь-яке завдання з класу NP можна буде вирішити швидко (за поліноміальний час). Однак наукове товариство схиляється в бік негативної відповіді на це питання. Крім того, не доведено і строгість включення до ширших класів, наприклад, в PSPACE, але рівність P і PSPACE виглядає нині дуже сумнівно.

Приклади

  • Стандартний алгоритм множення матриць вимагає n3 операцій множення (хоча існують більш швидкі алгоритми, які теж мають поліноміальну швидкість, як, наприклад, алгоритм Штрассена).
  • Степінь многочлена рідко буває великим. Один з таких випадків — запропонований в 2002 індійськими математиками тест Агравала — Каяла — Сакса, який з'ясовує, чи є число n простим, за O(log6n) операцій.

Завдання, приналежність яких класу P невідома

Існує багато задач, для яких не знайдено поліноміального алгоритму, але не доведено, що його не існує. Відповідно, невідомо, належать такі завдання класу P {\displaystyle P} . Ось деякі з них:

Примітки

  1. Рейнгольд, Нивергельт Ю., Део Н. (1980). Комбинаторные Алгоритмы (рос.) . Москва: Мир. с. 442—443.
  2. John E. Hopcroft, Rajeev Motwani, Jeffrey D. Ullman (2001). Introduction to Automata Theory, Languages and Computation (англ.) (вид. 2-ге). Addison-Wesley. ISBN 0-201-44124-1.

Див. також

  • Портал «Математика»
  • п
  • о
  • р
Вважаються легкими
Припускаються складними
Вважаються складними
  • EXPTIME
  • NEXPTIME
  • EXPSPACE
  • 2-EXPTIME
  • PR
  • RE
  • Co-RE
  • RE-complete
  • Co-RE-complete
  • PH
Ієрархії
  • п
  • о
  • р
NP-повні задачі
Класифікація
Основи
NP-повна задача  · Клас складності NP  · Клас складності P
Задачі
Теорія складності обчислень
Логічні ігри
та головоломки
Списки
21 NP-повна задача Карпа  · Список NP-повних задач
Дослідники
Див. також
Ця стаття потребує додаткових посилань на джерела для поліпшення її перевірності. Будь ласка, допоможіть удосконалити цю статтю, додавши посилання на надійні (авторитетні) джерела. Зверніться на сторінку обговорення за поясненнями та допоможіть виправити недоліки.
Матеріал без джерел може бути піддано сумніву та вилучено.
(грудень 2015)
Алгоритми Це незавершена стаття про алгоритми.
Ви можете допомогти проєкту, виправивши або дописавши її.