Voglio cancellare un elemento da un vettore usando il metodo di cancellazione. Ma il problema qui è che non è garantito che l'elemento si presenti solo una volta nel vettore. Potrebbe essere presente più volte e devo cancellarle tutte. Il mio codice è qualcosa del genere:
void erase(std::vector<int>& myNumbers_in, int number_in)
{
std::vector<int>::iterator iter = myNumbers_in.begin();
std::vector<int>::iterator endIter = myNumbers_in.end();
for(; iter != endIter; ++iter)
{
if(*iter == number_in)
{
myNumbers_in.erase(iter);
}
}
}
int main(int argc, char* argv[])
{
std::vector<int> myNmbers;
for(int i = 0; i < 2; ++i)
{
myNmbers.push_back(i);
myNmbers.push_back(i);
}
erase(myNmbers, 1);
return 0;
}
Questo codice ovviamente si arresta in modo anomalo perché sto cambiando la fine del vettore durante l'iterazione. Qual è il modo migliore per ottenere questo risultato? Esiste un modo per farlo senza iterare più volte nel vettore o creare un'altra copia del vettore?
std::remove()
sposta gli elementi in modo tale che gli elementi da rimuovere vengano sovrascritti. L'algoritmo non cambia la dimensione del contenitore e se glin
elementi vengono rimossi non è definito quali sono gli ultimin
elementi.