std::experimental::erase (std::vector)
From cppreference.com
< cpp | experimental
C++
Experimental
| Technical Specification | ||||
| Filesystem library (filesystem TS) | ||||
| Library fundamentals (library fundamentals TS) | ||||
| Library fundamentals 2 (library fundamentals TS v2) | ||||
| Library fundamentals 3 (library fundamentals TS v3) | ||||
| Extensions for parallelism (parallelism TS) | ||||
| Extensions for parallelism 2 (parallelism TS v2) | ||||
| Extensions for concurrency (concurrency TS) | ||||
| Extensions for concurrency 2 (concurrency TS v2) | ||||
| Concepts (concepts TS) | ||||
| Ranges (ranges TS) | ||||
| Reflection (reflection TS) | ||||
| Mathematical special functions (special functions TR) | ||||
| Experimental Non-TS | ||||
| Pattern Matching | ||||
| Linear Algebra | ||||
| std::execution | ||||
| Contracts | ||||
| 2D Graphics |
Library fundamentals v2
|
|
Merged into ISO C++ The functionality described on this page was merged into the mainline ISO C++ standard as of 11/2018, see std::erase (since C++20) |
| Defined in header <experimental/vector>
|
||
| template< class T, class A, class U > void erase( std::vector<T, A>& c, const U& value ); |
(library fundamentals TS v2) | |
Erases all elements that compare equal to value from the container. Equivalent to c.erase(std::remove(c.begin(), c.end(), value), c.end();.
Contents |
[edit] Parameters
| c | - | container from which to erase |
| value | - | value to be removed |
[edit] Complexity
Linear.
[edit] Example
Run this code
#include <experimental/vector> #include <iostream> auto show = [](const auto& container) { for (auto e : container) std::cout << e; std::cout << '\n'; }; int main() { std::vector<int> data{1, 1, 4, 1, 2, 1}; show(data); std::experimental::erase(data, 1); show(data); }
Output:
11141112111 42
[edit] See also
| removes elements satisfying specific criteria (function template) [edit] | |
| (library fundamentals 2 TS) |
erases all elements satisfying a predicate from a std::vector (function template) [edit] |