Partilhar via


multiset::erase

Remove um elemento ou um intervalo de elementos em um multiset das posições especificadas ou removendo os elementos que correspondem a uma chave especificada.

iterator erase(
   iterator _Where
);
iterator erase(
   iterator _First,
   iterator _Last
);
size_type erase(
   const key_type& _Key
);

Parâmetros

  • _Where
    Posição do elemento ser removido de multiset.

  • _First
    A posição do primeiro elemento removeu de multiset.

  • _Last
    Posicione apenas além do último elemento removido de multiset.

  • _Key
    A chave de elementos a serem removidos de multiset.

Valor de retorno

Para as primeiras duas funções de membro, um iterador bidirecional que designa o primeiro elemento que permanece além de todos os elementos, removidos ou um ponteiro ao final do multiset se nenhum tal elemento existe.

ObservaçãoObservação

Esse tipo de retorno não está de acordo com o padrão C++.

Para a terceira função de membro, retorna o número de elementos que tenham sido removidos de multiset.

Comentários

Em alguns casos, esse método pode lançar uma exceção de out_of_range .

Exemplo

A o criar este exemplo com o sinalizador de /Wp64 ou em uma plataforma de 64 bits, o compilador que avisará C4267 será gerado.Para obter mais informações sobre este aviso, consulte C4267 de aviso (nível 3) do compilador.

// multiset_erase.cpp
// compile with: /EHsc
#include <set>
#include <iostream>

int main()
{
    using namespace std;
    multiset<int> ms1, ms2, ms3;
    multiset<int>::iterator pIter, Iter1, Iter2;
    int i;
    multiset<int>::size_type n;

    for (i = 1; i < 5; i++)
    {
        ms1.insert(i);
        ms2.insert(i * i);
        ms3.insert(i - 1);
    }

    // The 1st member function removes an element at a given position
    Iter1 = ++ms1.begin();
    ms1.erase(Iter1);

    cout << "After the 2nd element is deleted, the multiset ms1 is:" ;
    for (pIter = ms1.begin(); pIter != ms1.end(); pIter++)
        cout << " " << *pIter;
    cout << "." << endl;

    // The 2nd member function removes elements
    // in the range [_First, _Last)
    Iter1 = ++ms2.begin();
    Iter2 = --ms2.end();
    ms2.erase(Iter1, Iter2);

    cout << "After the middle two elements are deleted, "
         << "the multiset ms2 is:" ;
    for (pIter = ms2.begin(); pIter != ms2.end(); pIter++)
        cout << " " << *pIter;
    cout << "." << endl;

    // The 3rd member function removes elements with a given _Key
    ms3.insert(2);
    n = ms3.erase(2);

    cout << "After the element with a key of 2 is deleted,\n"
         << "the multiset ms3 is:" ;
    for (pIter = ms3.begin(); pIter != ms3.end(); pIter++)
        cout << " " << *pIter;
    cout << "." << endl;

    // The 3rd member function returns the number of elements removed
    cout << "The number of elements removed from ms3 is: "
         << n << "." << endl;

    // The dereferenced iterator can also be used to specify a key
    Iter1 = ++ms3.begin();
    ms3.erase(Iter1);

    cout << "After another element with a key"
         << endl;
    cout  << "equal to that of the 2nd element is deleted, "
          << "the multiset ms3 is:" ;
    for (pIter = ms3.begin(); pIter != ms3.end(); pIter++)
        cout << " " << *pIter;
    cout << "." << endl;
}
  
  
  
  
  

Requisitos

Cabeçalho: <set>

namespace: STD

Consulte também

Referência

multiset Class

Standard Template Library