map 的删除错误

fx397993401 2011-12-03 09:00:53
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 的 字符串 。
...全文
123 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
ssissi821 2011-12-08
  • 打赏
  • 举报
回复
for(; iter != dictmap.end(); )
{
if(iter->second < 3)
iter = dictmap.erase(iter++);
else
iter++;
}


ssissi821 2011-12-08
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 masterluo 的回复:]
用erase删除后,迭代器将会失效。但erase会返回下一个迭代器。
故有两种改变方法:
itr = dictmap.erase(itr) (不推荐,有些版本的STL可能返回值是void)

dictmap.erase(itr++)
[/Quote]
一看这就是行家。
map<string ,int >::iterator iter = dictmap.begin();
for(; iter != dictmap.end(); )
{
if(iter->second < 3)
dictmap.erase(iter++);
else
iter++;
}

fx397993401 2011-12-05
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 mingliang1212 的回复:]

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

你这个方案 会导致死循环 ,在我的电脑上 跑自己的测试数据 最多10s ,这个十分钟都出不来
MasterLuo 2011-12-04
  • 打赏
  • 举报
回复
用erase删除后,迭代器将会失效。但erase会返回下一个迭代器。
故有两种改变方法:
itr = dictmap.erase(itr) (不推荐,有些版本的STL可能返回值是void)

dictmap.erase(itr++)
heloworld404 2011-12-04
  • 打赏
  • 举报
回复
[Quote=引用楼主 fx397993401 的回复:]
map<string ,int >::iterator iter = dictmap.begin();
for(; iter != dictmap.end(); iter ++ )
{
if(iter->second < 3)
dictmap.erase(iter);
}

生成的 dictmap ,是 stri……
[/Quote]
这样试试
map<string ,int >::iterator iter = dictmap.begin();
for(; iter != dictmap.end(); iter ++ )
{
if(iter->second < 3)
dictmap.erase(iter->first);
}
iamnobody 2011-12-03
  • 打赏
  • 举报
回复
for(; iter != dictmap.end(); )
{
if(iter->second < 3)
iter = dictmap.erase(iter);
else
iter++;
}

64,637

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧