消去メソッドを使用してベクトルから要素をクリアしたいのですが。しかし、ここでの問題は、要素がベクトル内で1回だけ発生することが保証されていないことです。それは複数回存在する可能性があり、それらをすべてクリアする必要があります。私のコードは次のようなものです:
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;
}
このコードは、繰り返し処理中にベクターの終わりを変更しているため、明らかにクラッシュします。これを達成するための最良の方法は何ですか?つまり、ベクターを複数回繰り返したり、ベクターのコピーをもう1つ作成したりせずに、これを行う方法はありますか?
std::remove()
削除する要素が上書きされるように要素をシフトします。アルゴリズムはコンテナのサイズを変更しません。n
要素が削除された場合、最後のn
要素は未定義です。