首页 > 编程 > C++ > 正文

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

2020-01-26 14:20:20
字体:
来源:转载
供稿:网友

1.连续内存序列容器(vector,string,deque)

序列容器的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已经++了,正好满足我们的需要。

以上就是小编为大家带来的C++中vector和map的删除方法(推荐)全部内容了,希望大家多多支持武林网~

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表