hash_multimap::erase (STL/CLR)
Quita los elementos en las posiciones especificadas.
iterator erase(iterator where);
iterator erase(iterator first, iterator last);
bool erase(key_type key)
Parámetros
first
Inicio del intervalo que se va a borrar.clave
Valor de clave que se va a borrar.last
Final del intervalo que se va a borrar.donde
Elemento que se va a borrar.
Comentarios
La primera función miembro quita el elemento de la secuencia controlada designada por a where, y devuelve un iterador que señala el primer elemento que permanece más allá del elemento quitado, o hash_multimap::end (STL/CLR)() si no existe ese elemento.Se utiliza para quitar un solo elemento.
La segunda función miembro quita elementos de la secuencia controlada en el intervalo [first,last), y devuelve un iterador que señala el primer elemento que permanece más allá de cualquier elemento quitado, o end() si no existe ningún elemento.Se utiliza para quitar elementos cero o más contiguo.
La tercera función miembro quita cualquier elemento de la secuencia controlada cuya clave tiene equivalente de ordenación a key, y devuelve el número de elementos eliminados.Se utiliza para quitar y para contar todos los elementos que coinciden con una clave especificada.
Cada borradura de elemento lleva tiempo proporcional al logaritmo del número de elementos de la secuencia controlada.
Ejemplo
// cliext_hash_multimap_erase.cpp
// compile with: /clr
#include <cliext/hash_map>
typedef cliext::hash_multimap<wchar_t, int> Myhash_multimap;
int main()
{
cliext::hash_multimap<wchar_t, int> c1;
c1.insert(cliext::hash_multimap<wchar_t, int>::make_value(L'a', 1));
c1.insert(cliext::hash_multimap<wchar_t, int>::make_value(L'b', 2));
c1.insert(cliext::hash_multimap<wchar_t, int>::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (cliext::hash_multimap<wchar_t, int>::value_type elem in c1)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
// erase an element and reinspect
cliext::hash_multimap<wchar_t, int>::iterator it =
c1.erase(c1.begin());
System::Console::WriteLine("erase(begin()) = [{0} {1}]",
it->first, it->second);
// add elements and display " b c d e"
c1.insert(cliext::hash_multimap<wchar_t, int>::make_value(L'd', 4));
c1.insert(cliext::hash_multimap<wchar_t, int>::make_value(L'e', 5));
for each (cliext::hash_multimap<wchar_t, int>::value_type elem in c1)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
// erase all but end
it = c1.end();
it = c1.erase(c1.begin(), --it);
System::Console::WriteLine("erase(begin(), end()-1) = [{0} {1}]",
it->first, it->second);
System::Console::WriteLine("size() = {0}", c1.size());
// erase end
System::Console::WriteLine("erase(L'x') = {0}", c1.erase(L'x'));
System::Console::WriteLine("erase(L'e') = {0}", c1.erase(L'e'));
return (0);
}
Requisitos
encabezado: <cliext/hash_map>
Cliext deespacio de nombres: