In der Komplexitätstheorie wird die Potential- bzw. Potentialfunktionmethode verwendet, um die amortisierte Zeit- und Speicherkomplexität von Datenstrukturen zu messen. Dabei wird die Komplexität über eine Sequenz von Operationen berechnet, was die Kosten von seltenen, aber teuren Operationen auf die Sequenz von Operationen verteilt und damit glättet.
Ziel dabei ist es, jeder Operation auf der betrachteten Datenstruktur einen mittleren Kostenwert zuzuweisen, um über diese die erwartete Laufzeit einer beliebigen Folge von Operationen nach oben abzuschätzen. Im Unterschied zur Bankkonto-Methode werden die Kosten einer Operation nicht im Voraus festgesetzt, sondern hergeleitet. Hierzu wird eine Potentialfunktion eingeführt. Diese ordnet jedem inneren Zustand der Datenstruktur ihr Potential zu. Seien nun die maximalen realen Kosten der Operation , so ergibt sich der amortisierte Aufwand als:
Gilt nun, dass das Potential des Initialzustandes für alle Operationen einer beliebigen Operationenfolge nie unterschritten wird:
Dann ist die Summe der realen Kosten nie höher als die der amortisierten Kosten:
Existiert nun beispielsweise eine Konstante , welche die obere Grenze der amortisierten Kosten jeder Operation angibt:
So können die Gesamtkosten der Operationenfolge mit Operationen mit:
angegeben werden.
Literatur
- Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, Clifford Stein: Introduction to Algorithms. 2. Auflage. MIT Press, Cambridge MA 2001, ISBN 0-262-03293-7, S. 412–415.
Quellen
- ↑ Kurt Mehlhorn, Peter Sanders: Algorithms and Data Structures, 2008 Springer-Verlag Berlin Heidelberg, Kapitel 3.3.1 The Potential or Bank Account Method for Amortized Analysis, S. 72–74