序列容器的erase方法返回值是指向紧接在被删除元素之后的元素的有效迭代器,可以根据这个返回值来安全删除元素。

vector<int> c;

for(vector<int>::iterator it = c.begin(); it != c.end();)

{ if(need_delete())   

        it = c.erase(it);  

   else   

         ++it; 

}

 

2.关联容器(set,multiset,map,multimap)

关联容器的erase方法没有返回值,被删除的迭代器失效,所以删除前必须确保能得到下一个迭代器,可以用后置递增迭代器技术。

map<int,int> m;

for(map<int,int>::iterator it = m.begin(); it != m.end();)

{

    if(need_delete())    

            m.erase(it++);  

    else   

            ++it;

}

m.erase得到it的一个副本,在erase真正开始之前it已经递增了。

所以erase得到了当前的迭代器,在erase内部工作开始之前it已经++了,正好满足我们的需要。

相关文章:

  • 2022-12-23
  • 2022-03-04
  • 2021-04-20
  • 2021-06-27
  • 2022-12-23
  • 2022-12-23
  • 2022-01-09
  • 2022-02-05
猜你喜欢
  • 2022-02-12
  • 2021-12-31
  • 2022-03-06
  • 2022-12-23
  • 2022-12-23
  • 2021-05-31
相关资源
相似解决方案