源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

C++中vector和map的删除方法(推荐)

  • 时间:2022-12-13 11:46 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:C++中vector和map的删除方法(推荐)
[b]1.连续内存序列容器(vector,string,deque)[/b] 序列容器的erase方法返回值是指向紧接在被删除元素之后的元素的有效迭代器,可以根据这个返回值来安全删除元素。
vector<int> c;

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

{ if(need_delete())  

    it = c.erase(it); 

  else  

     ++it; 

}

[b]2.关联容器(set,multiset,map,multimap)[/b] 关联容器的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已经++了,正好满足我们的需要。 以上就是小编为大家带来的C++中vector和map的删除方法(推荐)全部内容了,希望大家多多支持编程素材网~
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部