table of contents
std::experimental::erase(std::list)(3) | C++ Standard Libary | std::experimental::erase(std::list)(3) |
NAME¶
std::experimental::erase(std::list) - std::experimental::erase(std::list)
Synopsis¶
Defined in header <experimental/list>
template< class T, class A, class U > (library fundamentals TS v2)
void erase( std::list<T, A>& c, const U& value );
Erases all elements that compare equal to value from the container.
Equivalent to
c.remove_if([&](auto& elem) { return elem == value; });.
Parameters¶
c - container from which to erase
value - value to be removed
Complexity¶
Linear.
Example¶
// Run this code
#include <experimental/list>
#include <iostream>
auto show = [](const auto& container)
{
for (auto e : container)
std::cout << e;
std::cout << '\n';
};
int main()
{
std::list<int> data{1, 1, 1, 4, 1, 1, 1, 2, 1, 1, 1};
show(data);
std::experimental::erase(data, 1);
show(data);
}
Output:¶
11141112111
42
Notes¶
Unlike std::list::remove, this function template accepts
heterogeneous types and
does not force a conversion to the container's value type before invoking the
==
operator.
See also¶
remove removes elements satisfying specific criteria
remove_if (function template)
remove removes elements satisfying specific criteria
remove_if (public member function of std::list<T,Allocator>)
erase_if (std::list) erases all elements satisfying a predicate from a
(library fundamentals 2 TS) std::list
(function template)
2024.06.10 | http://cppreference.com |