慎重选择删除元素的方法STL

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时,要对迭代器做后缀递增。
 

posted @ 2015-04-13 17:42  ht-beyond  阅读(172)  评论(0编辑  收藏  举报