+ -
当前位置:首页 → 问答吧 → map 的删除错误

map 的删除错误

时间:2011-12-03

来源:互联网

map<string ,int >::iterator iter = dictmap.begin();
  for(; iter != dictmap.end(); iter ++ )
  {
  if(iter->second < 3)
  dictmap.erase(iter);
  }

生成的 dictmap ,是 string : int ,int 记录 string 出现的次数,那么 我要删掉最出现次数少于三个的。
用上述代码实现 , 
但是 结果里面 确出现次数 为1 为 2 的 字符串 。

作者: fx397993401   发布时间: 2011-12-03

for(; iter != dictmap.end(); )
  {
  if(iter->second < 3)
  iter = dictmap.erase(iter);
  else 
  iter++;
  }

作者: mingliang1212   发布时间: 2011-12-03

引用楼主 fx397993401 的回复:
map<string ,int >::iterator iter = dictmap.begin();
for(; iter != dictmap.end(); iter ++ )
{
if(iter->second < 3)
dictmap.erase(iter);
}

生成的 dictmap ,是 stri……

这样试试
  map<string ,int >::iterator iter = dictmap.begin();
  for(; iter != dictmap.end(); iter ++ )
  {
  if(iter->second < 3)
  dictmap.erase(iter->first);
  }

作者: heloworld404   发布时间: 2011-12-04

用erase删除后,迭代器将会失效。但erase会返回下一个迭代器。
故有两种改变方法:
itr = dictmap.erase(itr) (不推荐,有些版本的STL可能返回值是void)

dictmap.erase(itr++)

作者: MasterLuo   发布时间: 2011-12-04