P (Komplexitätsklasse)

In der Komplexitätstheorie ist P (auch: PTIME) diejenige Komplexitätsklasse, die alle Entscheidungsprobleme enthält, die in Polynomialzeit für deterministische Turingmaschinen lösbar sind. Diese Problemklasse wird allgemein als die Klasse der „praktisch lösbaren“ Probleme betrachtet.

Eine Verallgemeinerung von P ist die Klasse NP. Die Probleme aus NP sind zwar ebenfalls in Polynomialzeit entscheidbar, jedoch wird hierfür ein nicht realisierbares, nämlich nichtdeterministisches Maschinenmodell eingesetzt. P ist sicher eine Teilmenge von NP. Es gehört jedoch zu den wichtigsten ungelösten Fragen der theoretischen Informatik, ob P = NP gilt (siehe auch P-NP-Problem).

P ist unter Komplementbildung abgeschlossen.

Formale Definition

Notation:

  • N 0 := { 0 , 1 , 2 , 3 , } {\displaystyle \mathbb {N} _{0}:=\{0,1,2,3,\dots \}} ist die Menge der natürlichen Zahlen mit Null.
  • Σ = { 0 , 1 } {\displaystyle \Sigma =\{0,1\}} ist das Alphabet einer formalen Sprache, das heißt jedes Wort ist eine binäre Zeichenfolge bestehend aus 0 {\displaystyle 0} und 1 {\displaystyle 1} .
  • Σ n {\displaystyle \Sigma ^{n}} bezeichnet die Menge aller binären Wörter der Länge n N 0 {\displaystyle n\in \mathbb {N} _{0}} .
  • Σ = n N 0 Σ n {\displaystyle \Sigma ^{*}=\bigcup _{n\in \mathbb {N} _{0}}\Sigma ^{n}} bezeichnet die (abzählbare) Menge aller endlich langen binären Wörter.

Ein Entscheidungsproblem kann nun als formale Sprache S Σ {\displaystyle S\subseteq \Sigma ^{*}} dargestellt werden. Jede Probleminstanz wird als Binärstring in Σ {\displaystyle \Sigma ^{*}} ausgedrückt, und S {\displaystyle S} enthält genau die Strings, die eine Instanz darstellen, auf die die richtige Antwort „ja“ lautet.

Ein Entscheidungsproblem S Σ {\displaystyle S\subseteq \Sigma ^{*}} ist effizient-lösbar, falls ein Algorithmus A : Σ { 0 , 1 } {\displaystyle A:\Sigma ^{*}\to \{0,1\}} in Polynomialzeit existiert, so dass für jedes x {\displaystyle x} gilt

A ( x ) = 1 x S . {\displaystyle A(x)=1\iff x\in S.}

Dann ist P {\displaystyle \mathbf {P} } die Klasse der effizient-lösbaren Entscheidungsprobleme, das heißt[1]

P = { S : ( A ) ( x ) [ A ( x ) = 1 x S A  poly ] } {\displaystyle \mathbf {P} =\{S:(\exists A)(\forall x)[A(x)=1\iff x\in S\wedge A{\text{ poly}}]\}}

Erläuterungen

Ein Algorithmus kann als deterministische Turing-Maschine aufgefasst werden.

Wir haben ein paar Vereinfachungen vorgenommen. Eigentlich meinen wir das Entscheidungsproblem von S {\displaystyle S} , aber häufig identifiziert man S {\displaystyle S} mit seinem Entscheidungsproblem. Auch den Begriff des Algorithmus haben wir vereinfacht, da korrekterweise A {\displaystyle A} nur die dazugehörige Funktion f A : { 0 , 1 } { 0 , 1 } { } {\displaystyle f_{A}:\{0,1\}^{*}\to \{0,1\}\cup \{\bot \}} berechnet, wobei {\displaystyle \bot } Fehler bedeutet (es ging etwas schief), mit der das Problem gelöst wird. Wir haben A {\displaystyle A} mit f A {\displaystyle f_{A}} identifiziert aber auf den Endzustand {\displaystyle \bot } verzichtet.

Beziehung zu anderen Komplexitätsklassen

Die folgenden Beziehungen sind bekannt:

L ⊆ NL ⊆ LOGCFL ⊆NC ⊆ P ⊆ NP ⊆ PSPACE = NPSPACE ⊆ EXPTIME ⊆ NEXPTIME ⊆ EXPSPACE = NEXPSPACE
LOGCFL {\displaystyle \not =} PSPACE {\displaystyle \not =} EXPSPACE
P {\displaystyle \not =} EXPTIME

P-Vollständigkeit

Ein Entscheidungsproblem A {\displaystyle A} heißt P-vollständig genau dann, wenn es in der Komplexitätsklasse P liegt und wenn jedes Problem in P durch eine Berechnung mit logarithmischem Platzverbrauch auf A {\displaystyle A} reduziert werden kann, das heißt, wenn jede dieser Reduktionen in der Komplexitätsklasse L liegt (siehe auch: Vollständigkeit in der Komplexitätstheorie).

Ein bekanntes P-vollständiges Problem ist das Circuit-Value-Problem, bei dem bestimmt werden soll, ob das Ergebnis eines Booleschen Schaltkreises bei gegebener Eingabe einer gegebenen Ausgabe entspricht. Diese Probleme gehören zu den schwersten, noch effizient lösbaren Problemen aus der Komplexitätsklasse P. P-vollständige Probleme sind (momentan) schwer zu parallelisieren.

Bekannte Probleme in P

Sehr viele Probleme liegen in P, was im Allgemeinen nicht besonders wahrgenommen wird; in der Regel kennt man dann auch einen geeigneten Algorithmus (so das Sortierungsproblem mit z. B. Quicksort, Laufzeit O ( n 2 ) {\displaystyle {\mathcal {O}}(n^{2})} usw.).

P-vollständige Probleme

  • P. In: Complexity Zoo. (englisch)
  • A Compendium of Problems Complete for P (englisch)

Einzelnachweise

  1. Oded Goldreich: P, NP, and NP-Completeness: The Basics of Computational Complexity. Hrsg.: Cambridge University Press. 2010, ISBN 978-0-521-19248-4 (englisch).