std::forward_list<T,Allocator>:: remove, remove_if
| (1) | ||
|
void
remove
(
const
T
&
value
)
;
|
(seit C++11)
(bis C++20) |
|
|
size_type remove
(
const
T
&
value
)
;
|
(seit C++20)
(constexpr seit C++26) |
|
| (2) | ||
|
template
<
class
UnaryPred
>
void remove_if ( UnaryPred p ) ; |
(seit C++11)
(bis C++20) |
|
|
template
<
class
UnaryPred
>
size_type remove_if ( UnaryPred p ) ; |
(seit C++20)
(constexpr seit C++26) |
|
Entfernt alle Elemente, die bestimmte Kriterien erfüllen.
Macht nur die Iteratoren und Referenzen auf die entfernten Elemente ungültig.
Inhaltsverzeichnis |
Parameter
| value | - | Wert der zu entfernenden Elemente |
| p | - |
unäres Prädikat, das
true
zurückgibt, wenn das Element entfernt werden soll.
Der Ausdruck
p
(
v
)
muss für jedes Argument
|
| Typanforderungen | ||
-
UnaryPred
muss die Anforderungen von
Predicate
erfüllen.
|
||
Rückgabewert
|
(keine) |
(bis C++20) |
|
Die Anzahl der entfernten Elemente. |
(seit C++20) |
Komplexität
Gegeben N als std:: distance ( begin ( ) , end ( ) ) :
Hinweise
| Feature-Test Makro | Wert | Std | Funktion |
|---|---|---|---|
__cpp_lib_list_remove_return_type
|
201806L
|
(C++20) | Ändern des Rückgabetyps |
Beispiel
#include <forward_list> #include <iostream> int main() { std::forward_list<int> l = {1, 100, 2, 3, 10, 1, 11, -1, 12}; auto count1 = l.remove(1); std::cout << count1 << " elements equal to 1 were removed\n"; auto count2 = l.remove_if([](int n){ return n > 10; }); std::cout << count2 << " elements greater than 10 were removed\n"; std::cout << "Finally, the list contains: "; for (int n : l) std::cout << n << ' '; std::cout << '\n'; }
Ausgabe:
2 Elemente gleich 1 wurden entfernt 3 Elemente größer als 10 wurden entfernt Abschließend enthält die Liste: 2 3 10 -1
Siehe auch
|
Entfernt Elemente, die bestimmte Kriterien erfüllen
(Funktions-Template) |