比如我们现在有如下代码:
map<string,int>tmp;
for(auto i = tmp.begin();i!=tmp.end();++i)
{
for(int j = 0;j<tmp->first;++j)
{
if(tmp->first[j] == 55)
{
tmp.erase(i);
break;
}
}
}
以上代码看上去没有啥错误!但当执行这一段时,会出错!这是由于在map中删除某一元素时,相应指向的迭代器就会失效,不能再进行相加操作!但是我们可以利用性质:erase之后返回指向删除元素之后元素的迭代器!
修改之后:
map<string,int>tmp;
auto i = tmp.begin();
while(i!=tmp.end())
{
for(int j = 0;j<tmp->first;++j)
{
if(tmp->first[j] == 10)
{
i = tmp.erase(i); //erase之后返回指向删除元素之后元素的迭代器
i--; //这里要是不-1的话,跳出这个循环后又要+1,就会使得i加了2!!!
break;
}
}
i++;
}
以上情况特别适合两个循环嵌套的情况!要熟练这种操作!!!