Python - Amortisierte Analyse
Bei der amortisierten Analyse wird die Laufzeit für die Abfolge von Vorgängen in einem Programm geschätzt, ohne die Spanne der Datenverteilung in den Eingabewerten zu berücksichtigen. Ein einfaches Beispiel ist, dass das Finden eines Werts in einer sortierten Liste schneller ist als in einer unsortierten Liste. Wenn die Liste bereits sortiert ist, spielt es keine Rolle, wie verteilt die Daten sind. Aber natürlich hat die Länge der Liste einen Einfluss darauf, wie viele Schritte der Algorithmus durchlaufen muss, um das Endergebnis zu erhalten.
Wir sehen also, dass, wenn die anfänglichen Kosten eines einzelnen Schritts zum Erhalten einer sortierten Liste hoch sind, die Kosten nachfolgender Schritte zum Finden eines Elements beträchtlich niedrig werden. Die amortisierte Analyse hilft uns also, eine Grenze für die Worst-Case-Laufzeit einer Abfolge von Vorgängen zu finden. Es gibt drei Ansätze für die amortisierte Analyse.
Accounting Method- Dies beinhaltet die Zuordnung von Kosten zu jeder durchgeführten Operation. Wenn der eigentliche Vorgang schneller als die zugewiesene Zeit abgeschlossen ist, wird in der Analyse ein positives Guthaben angesammelt. Im umgekehrten Szenario handelt es sich um eine negative Gutschrift. Um diese angesammelten Credits zu verfolgen, verwenden wir eine Stapel- oder Baumdatenstruktur. Die Operationen, die früh ausgeführt werden (wie das Sortieren der Liste), haben hohe amortisierte Kosten, aber die Operationen, die spät in der Folge ausgeführt werden, haben niedrigere amortisierte Kosten, wenn das kumulierte Guthaben verwendet wird. Die fortgeführten Anschaffungskosten sind also eine Obergrenze der tatsächlichen Kosten.
Potential Method- Bei dieser Methode wird das gespeicherte Guthaben für zukünftige Operationen als mathematische Funktion des Zustands der Datenstruktur verwendet. Die Bewertung der mathematischen Funktion und der fortgeführten Anschaffungskosten sollte gleich sein. Wenn also die tatsächlichen Kosten höher sind als die fortgeführten Anschaffungskosten, verringert sich das Potenzial und es wird für zukünftige Operationen verwendet, die teuer sind.
Aggregate analysis - Bei dieser Methode schätzen wir die Obergrenze für die Gesamtkosten von n Schritten. Die fortgeführten Anschaffungskosten sind eine einfache Aufteilung der Gesamtkosten und der Anzahl der Schritte (n).