std::erase, std::erase_if (std::vector) - cppreference.com
De cppreference.com
| Definido en el archivo de encabezado |
||
|
|
(1) | (desde C++20) |
|
|
(2) | (desde C++20) |
1) Borra del contenedor todos los elementos que se comparan iguales a value. Equivalente a
auto it = std::remove(c.begin(), c.end(), value); auto r = std::distance(it, c.end()); c.erase(it, c.end()); return r;
2) Borra del contenedor todos los elementos que satisfacen el predicado pred. Equivalente a
auto it = std::remove_if(c.begin(), c.end(), pred); auto r = std::distance(it, c.end()); c.erase(it, c.end()); return r;
Parámetros
| c | - | Contenedor del cual borrar. |
| value | - | Valor a borrar. |
| pred | - | Predicado unario que devuelve true si el elemento debería ser borrado.
La expresión |
Valor de retorno
El número de elementos borrados.
Complejidad
Lineal.
Ejemplo
#include <iostream> #include <numeric> #include <vector> void imprimir_contenedor(const std::vector<char>& c) { for (auto x : c) { std::cout << x << ' '; } std::cout << '\n'; } int main() { std::vector<char> cnt(10); std::iota(cnt.begin(), cnt.end(), '0'); std::cout << "Inicio:\n"; imprimir_contenedor(cnt); std::erase(cnt, '3'); std::cout << "Borrar \'3\':\n"; imprimir_contenedor(cnt); auto borrados = std::erase_if(cnt, [](char x) { return (x - '0') % 2 == 0; }); std::cout << "Borrar todos los pares:\n"; imprimir_contenedor(cnt); std::cout << "En total se borraron " << borrados << " pares.\n"; }
Salida:
Inicio: 0 1 2 3 4 5 6 7 8 9 Borrar '3': 0 1 2 4 5 6 7 8 9 Borrar todos los pares: 1 5 7 9 En total se borraron 5 pares.