Python - Haufen
Heap ist eine spezielle Baumstruktur, in der jeder übergeordnete Knoten kleiner oder gleich seinem untergeordneten Knoten ist. Dann heißt es Min Heap. Wenn jeder übergeordnete Knoten größer oder gleich seinem untergeordneten Knoten ist, wird er als maximaler Heap bezeichnet. Es ist sehr nützlich, Prioritätswarteschlangen zu implementieren, bei denen dem Warteschlangenelement mit höherer Gewichtung bei der Verarbeitung eine höhere Priorität eingeräumt wird. Eine ausführliche Diskussion über Haufen finden Sie auf unserer Website hier. Bitte studieren Sie es zuerst, wenn Sie neu in der Kopfdatenstruktur sind. In diesem Kapitel sehen wir die Implementierung der Heap-Datenstruktur mit Python.
Erstellen Sie einen Heap
Ein Heap wird mithilfe der in Python integrierten Bibliothek mit dem Namen heapq erstellt. Diese Bibliothek verfügt über die relevanten Funktionen, um verschiedene Operationen an der Heap-Datenstruktur auszuführen. Unten finden Sie eine Liste dieser Funktionen.
- heapify - Diese Funktion konvertiert eine reguläre Liste in einen Heap. Im resultierenden Heap wird das kleinste Element an die Indexposition 0 verschoben. Die restlichen Datenelemente werden jedoch nicht unbedingt sortiert.
- Heappush - Diese Funktion fügt dem Heap ein Element hinzu, ohne den aktuellen Heap zu ändern.
- heappop - Diese Funktion gibt das kleinste Datenelement aus dem Heap zurück.
- heapreplace - Diese Funktion ersetzt das kleinste Datenelement durch einen neuen Wert, der in der Funktion angegeben wird.
Einen Heap erstellen
Ein Heap wird erstellt, indem einfach eine Liste von Elementen mit der Heapify-Funktion verwendet wird. Im folgenden Beispiel stellen wir eine Liste von Elementen bereit und die Heapify-Funktion ordnet die Elemente neu, um das kleinste Element an die erste Position zu bringen.
import heapq
H = [21,1,45,78,3,5]
# Use heapify to rearrange the elements
heapq.heapify(H)
print(H)
Wenn der obige Code ausgeführt wird, wird das folgende Ergebnis erzeugt:
[1, 3, 5, 78, 21, 45]
Einfügen in den Haufen
Durch das Einfügen eines Datenelements in einen Heap wird das Element immer am letzten Index hinzugefügt. Sie können die Heapify-Funktion jedoch erneut anwenden, um das neu hinzugefügte Element nur dann in den ersten Index aufzunehmen, wenn es den kleinsten Wert hat. Im folgenden Beispiel fügen wir die Nummer 8 ein.
import heapq
H = [21,1,45,78,3,5]
# Covert to a heap
heapq.heapify(H)
print(H)
# Add element
heapq.heappush(H,8)
print(H)
Wenn der obige Code ausgeführt wird, wird das folgende Ergebnis erzeugt:
[1, 3, 5, 78, 21, 45]
[1, 3, 5, 78, 21, 45, 8]
Vom Haufen entfernen
Mit dieser Funktion können Sie das Element beim ersten Index entfernen. Im folgenden Beispiel entfernt die Funktion das Element immer an der Indexposition 1.
import heapq
H = [21,1,45,78,3,5]
# Create the heap
heapq.heapify(H)
print(H)
# Remove element from the heap
heapq.heappop(H)
print(H)
Wenn der obige Code ausgeführt wird, wird das folgende Ergebnis erzeugt:
[1, 3, 5, 78, 21, 45]
[3, 21, 5, 78, 45]
In einem Haufen ersetzen
Die Heapreplace-Funktion entfernt immer das kleinste Element des Heaps und fügt das neue eingehende Element an einer Stelle ein, die in keiner Reihenfolge festgelegt ist.
import heapq
H = [21,1,45,78,3,5]
# Create the heap
heapq.heapify(H)
print(H)
# Replace an element
heapq.heapreplace(H,6)
print(H)
[1, 3, 5, 78, 21, 45]
[3, 6, 5, 78, 21, 45]