Heim > Backend-Entwicklung > C++ > Array-Darstellung des binären Heaps

Array-Darstellung des binären Heaps

PHPz
Freigeben: 2023-09-04 22:45:05
nach vorne
747 Leute haben es durchsucht

Ein vollständiger Binärbaum, der der Heap-Sortierungseigenschaft folgt, wird als Binär-Heap bezeichnet.

Basierend darauf, wie ein binärer Heap sortiert ist, kann er in zwei Typen unterteilt werden:

Minimaler Heap ist ein Heap, bei dem der Wert eines Knotens größer oder gleich dem Wert seines übergeordneten Knotens ist. Der Wurzelknoten eines Min-Heaps ist der kleinste.

Max Heap ist ein Heap, bei dem der Wert eines Knotens kleiner oder gleich dem Wert seines übergeordneten Knotens ist. Der Wurzelknoten des Max-Heaps ist der größte.

Der Wert eines binären Heaps wird normalerweise als Array dargestellt. Die Array-Darstellung eines binären Heaps lautet wie folgt:

  • Der Index des Wurzelelements ist 0.

  • Wenn i der Index eines Knotens im Array ist, lauten die Indizes anderer Knoten, die sich auf diesen Knoten beziehen, wie folgt:

    • Linkes Kind: (2*i)+1

    • Rechtes Kind : (2*i )+2

    • Übergeordneter Knoten: (i-1)/2

Mit den oben genannten Array-Darstellungsregeln können wir den Heap als Array darstellen:

Array-Darstellung des binären Heaps

Minimum Heap Array-Darstellung:
1... – Die Wurzel Knoten hat den Mindestwert. Der Wert des Knotens ist größer als der Wert des übergeordneten Knotens. Beispiel:

  • 1

    4

    7
6

9

. Array-Darstellung des binären Heaps10

8

Max Heap Array-Darstellung:
– Der Wurzelknoten hat den Maximalwert. Der Wert des Knotens ist kleiner als der Wert des übergeordneten Knotens. Beispiel:
  • 11

    8

    9
6

4

Array-Darstellung des binären Heaps5

1

Das obige ist der detaillierte Inhalt vonArray-Darstellung des binären Heaps. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:tutorialspoint.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage