<Effectives STL>笔记之在STL容器中删除元素的方法选择
2011-09-12 14:38
615 查看
1.要删除容器中特定值的所有对象“
如果容器是vector、string或者deque,则使用erase-remove习惯用法。
如果容器是list,则使用list::remove。
如果容器是一个标准关联容器,则使用它的erase成员函数。
2.要删除容器中满足特定判别式(条件)的所有对象:
如果容器是vector、string或者deque,则使用erase-remove_if习惯用法。
如果容器是list,则使用list::remove_if。
如果容器是一个标准关联容器,则使用remove_copy_if和swap,或者写一个循环遍历容器中的元素,记住当把迭代器传给erase是,要对它进行后缀递增。
3要在循环内部默写(除了删除对象之外的)操作:
如果容器是一个标准序列容器,则写一个循环来遍历容器中的元素,记住每次用erase时,要用它的返回值更新迭代器。
如果容器是一个标准关联容器,则写一个循环来遍历容器中的元素,记住每次用erase时,要对迭代器做后缀递增。
如果容器是vector、string或者deque,则使用erase-remove习惯用法。
如果容器是list,则使用list::remove。
如果容器是一个标准关联容器,则使用它的erase成员函数。
2.要删除容器中满足特定判别式(条件)的所有对象:
如果容器是vector、string或者deque,则使用erase-remove_if习惯用法。
如果容器是list,则使用list::remove_if。
如果容器是一个标准关联容器,则使用remove_copy_if和swap,或者写一个循环遍历容器中的元素,记住当把迭代器传给erase是,要对它进行后缀递增。
3要在循环内部默写(除了删除对象之外的)操作:
如果容器是一个标准序列容器,则写一个循环来遍历容器中的元素,记住每次用erase时,要用它的返回值更新迭代器。
如果容器是一个标准关联容器,则写一个循环来遍历容器中的元素,记住每次用erase时,要对迭代器做后缀递增。
相关文章推荐
- &lt;Effective STL&gt;笔记--关联容器
- &lt;Effective STL&gt;笔记--容器
- &lt;Effective STL&gt;笔记--仿函数
- &lt;Effective STL&gt;笔记--算法
- JSONP一种使用<script>元素获取数据的方法
- <C++Primer>第四版 阅读笔记 第二部分 “容器和算法”
- <仅是自己做笔记。。。系列-11>输入n,用最快的方法求Fibonacci数列的第n项。
- <<Effective STL>> 条款31 容器排序笔记
- 11/7/8 STL 映射容器 map< K , T > 学习笔记
- 讨论exe获取dll提供的单例,并获取单例所提供的带有vector<class A>& STL容器的返回值的情况-提供1种解决方法
- 选择删除STL标准容器元素的方法
- <textarea>里的内容保存MYSQL后,页面输出不换行的解决方法
- Java笔记7 Java基础加强<1>反射
- <s:property>标签从后台读取Date类型年份为两位在jsp页面显示的解决方法
- vector<char> 容器初始化 string 对象 两种方法
- STL序列式容器中删除元素的方法和陷阱一
- <像计算机科学家一样思考>笔记
- JSP 中使用<%@include%> 报 Duplicate local variable path 错误的解决方法
- STL 之容器:选择时机,删除元素,迭代器失效
- <转载学习>子类对父类构造方法调用小结