我想使用erase方法从向量中清除一个元素。但是问题在于该元素不能保证仅在向量中出现一次。它可能出现多次,而我需要清除所有的实例。我的代码大致如下:
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;
}
这段代码在迭代 vector 的同时修改了其结尾,导致程序崩溃。有什么更好的方法可以实现目标吗?也就是说,是否有任何不需要多次迭代向量或创建一个向量副本的方法来完成此操作?
std::remove()
函数会移动元素,以便覆盖需要删除的元素。该算法不会改变容器的大小,如果删除了n
个元素,则未定义最后的n
个元素是什么。 - wilhelmtellend()
,它会移除在begin()
和end()
之间的所有元素。如果begin()
等于end()
,则该范围内没有任何元素,因此不会删除任何东西(erase
同理)。 - Motti