std::forward_list::remove, std::forward_list::remove_if
From cppreference.com
< cpp | container | forward list
void remove( const T& value );
|
(since C++11) | |
template< class UnaryPredicate >
void remove_if( UnaryPredicate p ); |
(since C++11) | |
Removes all elements satisfying specific criteria. The first version removes all elements that are equal to value
, the second version removes all elements for which predicate p
returns true.
Contents |
[edit] Parameters
value | - | value of the elements to remove | |||||||||
p | - | unary predicate which returns true if the element should be removed. The signature of the predicate function should be equivalent to the following:
The signature does not need to have const &, but the function must not modify the objects passed to it. |
[edit] Return value
(none)
[edit] Complexity
linear in the size of the container
[edit] Example
#include <forward_list> #include <iostream> int main() { std::forward_list<int> l = { 1,100,2,3,10,1,11,-1,12 }; l.remove(1); // remove both elements equal to 1 l.remove_if([](int n){ return n > 10; }); // remove all elements greater than 10 for (int n : l) { std::cout << n << ' '; } std::cout << '\n'; }
Output:
2 3 10 -1
[edit] See also
removes elements satisfying specific criteria (function template) |