std::stable_partition
| Definiert in Header <algorithm> |
||
template< class BidirIt, class UnaryPred > BidirIt stable_partition( BidirIt first, BidirIt last, UnaryPred p ); |
(1) | (constexpr seit C++26) |
| template< class ExecutionPolicy, class BidirIt, class UnaryPred > BidirIt stable_partition( ExecutionPolicy&& policy, |
(2) | (seit C++17) |
[first, last) so um, dass alle Elemente, für die der Prädikat p true zurückgibt, vor den Elementen stehen, für die das Prädikat p false zurückgibt. Die relative Reihenfolge der Elemente wird beibehalten.|
std::is_execution_policy_v<std::decay_t<ExecutionPolicy>> ist true. |
(bis C++20) |
|
std::is_execution_policy_v<std::remove_cvref_t<ExecutionPolicy>> ist true. |
(seit C++20) |
Wenn eine der folgenden Bedingungen erfüllt ist, ist das Verhalten undefiniert
|
(bis C++11) |
|
(seit C++11) |
Inhalt |
[edit] Parameter
| first, last | - | Das Iteratorenpaar, das den Bereich der neu zu ordnenden Elemente definiert |
| policy | - | die Ausführungsrichtlinie, die verwendet werden soll |
| p | - | unäres Prädikat, das true zurückgibt, wenn das Element vor anderen Elementen geordnet werden soll. Der Ausdruck p(v) muss für jedes Argument |
| Typanforderungen | ||
-BidirIt muss die Anforderungen von LegacyBidirectionalIterator erfüllen. | ||
-UnaryPred muss die Anforderungen von Predicate erfüllen. | ||
[edit] Rückgabewert
Iterator auf das erste Element der zweiten Gruppe.
[edit] Komplexität
Gegeben sei N als std::distance(first, last).
[edit] Ausnahmen
Die Überladung mit einem Template-Parameter namens ExecutionPolicy meldet Fehler wie folgt
- Wenn die Ausführung einer Funktion, die als Teil des Algorithmus aufgerufen wird, eine Ausnahme auslöst und
ExecutionPolicyeine der Standardrichtlinien ist, wird std::terminate aufgerufen. Für jede andereExecutionPolicyist das Verhalten implementierungsabhängig. - Wenn dem Algorithmus der Speicher zur Neuzuweisung fehlt, wird std::bad_alloc ausgelöst.
[edit] Hinweise
Diese Funktion versucht, einen temporären Puffer zu allokieren. Schlägt die Allokation fehl, wird der weniger effiziente Algorithmus gewählt.
Implementierungen in libc++ und libstdc++ akzeptieren auch Bereiche, die von LegacyForwardIteratoren bezeichnet werden, als Erweiterung.
| Feature-Test-Makro | Wert | Std | Feature |
|---|---|---|---|
__cpp_lib_constexpr_algorithms |
202306L |
(C++26) | constexpr stabile Sortierung (1) |
[edit] Beispiel
#include <algorithm> #include <iostream> #include <vector> int main() { std::vector<int> v{0, 0, 3, -1, 2, 4, 5, 0, 7}; std::stable_partition(v.begin(), v.end(), [](int n) { return n > 0; }); for (int n : v) std::cout << n << ' '; std::cout << '\n'; }
Ausgabe
3 2 4 5 7 0 0 -1 0
[edit] 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 2150 | C++98 | std::stable_partition war nur dazu verpflichtet, einElement, das p erfüllt, vor ein Element zu stellen, das p nicht erfüllt |
korrigierte die Anforderung |
[edit] Siehe auch
| Teilt einen Bereich von Elementen in zwei Gruppen auf (Funktionstemplate) | |
| (C++20) |
Teilt Elemente in zwei Gruppen auf und behält dabei ihre relative Reihenfolge bei (Algorithmus-Funktionsobjekt) |