STL中利用迭代器循环删除容器中某元素的技巧
2014-12-16 11:08
260 查看
1.连续内存序列容器(vector,string,deque)序列容器的erase方法返回值是指向紧接在被删除元素之后的元素的有效迭代器,可以根据这个返回值来安全删除元素。
2.关联容器(set,multiset,map,multimap)
关联容器的erase方法没有返回值,被删除的迭代器失效,所以删除前必须确保能得到下一个迭代器,可以用“后置递增迭代器”技术。
m.erase得到it的一个副本,在erase真正开始之前it已经递增了。
所以erase得到了当前的迭代器,在erase内部工作开始之前it已经++了,正好满足我们的需要。
3.非连续内存序列容器(list)
只所以单独列出来是因为以上两种方法对list都适用,可依自己喜好选择。
转载处:点击打开链接
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已经++了,正好满足我们的需要。
3.非连续内存序列容器(list)
只所以单独列出来是因为以上两种方法对list都适用,可依自己喜好选择。
转载处:点击打开链接
相关文章推荐
- STL容器之删除元素,迭代器失效
- STL容器迭代过程中删除元素技巧(转)
- STL容器迭代过程中删除元素技巧(转)
- STL容器迭代过程中删除元素技巧
- 如何使用迭代器iterator循环删除容器中的元素?
- STL:循环删除容器中元素的方法和陷阱
- STL容器迭代过程中删除元素技巧
- 如何使用迭代器iterator循环删除容器中的元素?
- STL容器迭代过程中删除元素技巧(转)
- STL容器:删除元素,迭代器失效,选择时机
- stl容器在循环遍历中删除元素的方式
- (转)STL之容器:选择时机,删除元素,迭代器失效
- STL容器之删除元素,迭代器失效
- STL:循环删除容器中元素的方法和陷阱
- STL容器:删除元素,迭代器失效,选择时机
- STL之容器:选择时机,删除元素,迭代器失效
- STL:循环删除容器中元素的方法和陷阱
- stl容器用反向迭代器连续删除元素的方法
- STL容器迭代过程中删除元素技巧(转)
- STL之容器:选择时机,删除元素,迭代器失效