[C++ STL]这个向量迭代器问题,实在受不了了,程序简单,删除所有匹配的元素

2024-12-21 12:50:51
推荐回答(3个)
回答1:

你在删除itorb之前,做了itora++;运算,但是在删除itorb之后,itora就失效了,现在的itora指向了原来的下一个位置。虽然在后来又做了itora--;运算,但是在if外面又有一次itora++;,所以你现在已经把第二个6也跳过去了。
你如果要坚持自己删除的话,不用这么麻烦:
for(;itora != array.end();){
if(6 == *itora)
{
array.erase(itora);
print(array);
}
else
{
itora++;
}
}
array.erase(itora);之后,itora的值没变,但是因为后面所有的元素都往前移了一个位置,所以相当于itora自动做了一次++运算。

注意:对list就不能这么做了。

回答2:

erase 后 指针就已经改变

所以 在erase 就应该 将 itora = array.begin()

回答3:

vector::iterator it;
for(vector::const_iterator it = vt.begin();it!=vt.end();it++)
这句就有毛病了 it重复定义了
还有函数没有return啊