std::list<T,Allocator>::remove, remove_if
(1) | ||
void remove( const T& value ); | (until C++20) | |
size_type remove( const T& value ); | (since C++20) | |
(2) | ||
template< class UnaryPredicate > void remove_if( UnaryPredicate p ); | (until C++20) | |
template< class UnaryPredicate > size_type remove_if( UnaryPredicate p ); | (since C++20) |
Removes all elements satisfying specific criteria. Invalidates only the iterators and references to the removed elements.
value
(using operator==
).p
returns true
.Parameters
value | - | value of the elements to remove |
p | - | unary predicate which returns true if the element should be removed. The expression |
Type requirements | ||
-UnaryPredicate must meet the requirements of Predicate. |
Return value
(none) | (until C++20) |
The number of elements removed. | (since C++20) |
Complexity
Given \(\scriptsize N\)N as std::distance(begin(), end())
:
operator==
.p
.Notes
Feature-test macro | Value | Std | Feature |
---|---|---|---|
__cpp_lib_list_remove_return_type | 201806L | (C++20) | Change the return type |
Example
#include <list> #include <iostream> int main() { std::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'; }
Output:
2 elements equal to 1 were removed 3 elements greater than 10 were removed Finally, the list contains: 2 3 10 -1
Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 1207 | C++98 | it was unclear whether iterators and/or references will be invalidated | only invalidates iterators and references to the removed elements |
See also
removes elements satisfying specific criteria (function template) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/container/list/remove