Namensräume
Varianten
Aktionen

std::pop_heap

Von cppreference.com
< cpp‎ | algorithm
 
 
Algorithmenbibliothek
Beschränkte Algorithmen und Algorithmen für Bereiche (C++20)
Beschränkte Algorithmen, z.B. ranges::copy, ranges::sort, ...
Ausführungsrichtlinien (C++17)
Nicht-modifizierende Sequenzoperationen
Stapeloperationen
(C++17)
Suchoperationen
(C++11)                (C++11)(C++11)

Modifizierende Sequenzoperationen
Kopieroperationen
(C++11)
(C++11)
Tauschoperationen
Transformationsoperationen
Generierungsoperationen
Entfernungsoperationen
Ordnungsändernde Operationen
(bis C++17)(C++11)
(C++20)(C++20)
Stichprobenoperationen
(C++17)

Sortier- und verwandte Operationen
Partitionierungsoperationen
Sortieroperationen
Binäre Suchoperationen
(auf partitionierten Bereichen)
Mengenoperationen (auf sortierten Bereichen)
Zusammenführungsoperationen (auf sortierten Bereichen)
Heapoperationen
pop_heap
Minimum/Maximum-Operationen
(C++11)
(C++17)
Lexikographische Vergleichsoperationen
Permutationsoperationen
C-Bibliothek
Numerische Operationen
Operationen auf uninitialisiertem Speicher
 
Definiert in Header <algorithm>
template< class RandomIt >
void pop_heap( RandomIt first, RandomIt last );
(1) (constexpr seit C++20)
template< class RandomIt, class Compare >
void pop_heap( RandomIt first, RandomIt last, Compare comp );
(2) (constexpr seit C++20)

Vertauscht den Wert an der Position first mit dem Wert an der Position last - 1 und macht den Teilbereich [firstlast - 1) zu einem Heap. Dies hat den Effekt, das erste Element aus dem Heap [firstlast) zu entfernen.

1) [firstlast) ist ein Heap bezüglich operator<(bis C++20)std::less{}(seit C++20).
2) [firstlast) ist ein Heap bezüglich comp.

Wenn eine der folgenden Bedingungen erfüllt ist, ist das Verhalten undefiniert

  • [firstlast) ist leer.
  • [firstlast) ist kein Heap bezüglich des entsprechenden Vergleichers.
(bis C++11)
(seit C++11)

Inhalt

[bearbeiten] Parameter

first, last - das Iteratorenpaar, das den nicht-leeren binären Heap Bereich der zu modifizierenden Elemente definiert (Wurzelelement extrahieren)
comp - Ein Vergleichsfunktions-Objekt (d.h. ein Objekt, das die Anforderungen an Compare erfüllt), das true zurückgibt, wenn das erste Argument *weniger* als das zweite ist.

Die Signatur der Vergleichsfunktion sollte äquivalent zu Folgendem sein

bool cmp(const Type1& a, const Type2& b);

Obwohl die Signatur nicht const& haben muss, darf die Funktion die übergebenen Objekte nicht modifizieren und muss alle Werte vom Typ (möglicherweise const) Type1 und Type2 unabhängig von der Wertkategorie akzeptieren (daher ist Type1& nicht erlaubt, und auch nicht Type1, es sei denn, für Type1 ist ein Move äquivalent zu einer Kopie(seit C++11)).
Die Typen Type1 und Type2 müssen so beschaffen sein, dass ein Objekt vom Typ RandomIt dereferenziert und dann implizit in beide konvertiert werden kann.

Typanforderungen
-
RandomIt muss die Anforderungen an einen LegacyRandomAccessIterator erfüllen.
-
Compare muss die Anforderungen an Compare erfüllen.

[bearbeiten] Komplexität

Gegeben sei N als std::distance(first, last).

1) Höchstens 2log(N) Vergleiche mittels operator<(bis C++20)std::less{}(seit C++20).
2) Höchstens 2log(N) Aufrufe der Vergleichsfunktion comp.

[bearbeiten] Beispiel

#include <algorithm>
#include <iostream>
#include <string_view>
#include <type_traits>
#include <vector>
 
void println(std::string_view rem, const auto& v)
{
    std::cout << rem;
    if constexpr (std::is_scalar_v<std::decay_t<decltype(v)>>)
        std::cout << v;
    else
        for (int e : v)
            std::cout << e << ' ';
    std::cout << '\n';
}
 
int main()
{
    std::vector<int> v{3, 1, 4, 1, 5, 9};
 
    std::make_heap(v.begin(), v.end());
    println("after make_heap: ", v);
 
    std::pop_heap(v.begin(), v.end()); // moves the largest to the end
    println("after pop_heap:  ", v);
 
    int largest = v.back();
    println("largest element: ", largest);
 
    v.pop_back(); // actually removes the largest element
    println("after pop_back:  ", v);
}

Ausgabe

after make_heap: 9 5 4 1 1 3
after pop_heap:  5 3 4 1 1 9
largest element: 9
after pop_back:  5 3 4 1 1

[bearbeiten] Fehlerberichte

Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR angewendet auf Verhalten wie veröffentlicht Korrigiertes Verhalten
LWG 1205 C++98 das Verhalten war unklar, wenn [firstlast) leer war das Verhalten ist in diesem Fall undefiniert

[bearbeiten] Siehe auch

Fügt ein Element zu einem Max-Heap hinzu
(Funktionstemplate) [edit]
(C++11)
Prüft, ob der gegebene Bereich ein Max-Heap ist
(Funktionstemplate) [edit]
Findet den größten Teilbereich, der ein Max-Heap ist
(Funktionstemplate) [edit]
Erstellt aus einem Bereich von Elementen einen Max-Heap
(Funktionstemplate) [edit]
Verwandelt einen Max-Heap in einen aufsteigend sortierten Bereich von Elementen
(Funktionstemplate) [edit]
Entfernt das größte Element aus einem Max-Heap
(Algorithmus-Funktionsobjekt)[edit]