// for vector, deque
template <class Container, class T>
inline
void vector_erase(Container & c, T const& t)
{
c.erase(std::remove(c.begin(), c.end(), t), c.end());
}
template <class Container, class Pred>
inline
void vector_erase_if(Container & c, Pred pred)
{
c.erase(std::remove_if(c.begin(), c.end(), pred), c.end());
}
// for list, set, map
template <class Container, class T>
void list_erase(Container & c, T const& t)
{
typename Container::iterator
b = c.begin(), e = c.end(), prev = b;
while (b != e)
{
++b;
if (*prev == t) c.erase(prev);
prev = b;
}
}
template <class Container, class Pred>
void list_erase_if(Container & c, Pred pred)
{
typename Container::iterator
b = c.begin(), e = c.end(), prev = b;
while (b != e)
{
++b;
if (pred(*prev)) c.erase(prev);
prev = b;
}
}
# re: [STL] 循环中erase 回复 更多评论
2006-12-28 09:41 by
@eXile
如果需要打印出被删除的元素呢?
对于list,如果只要删除某个项,调用list.remove就可以了
# re: [STL] 循环中erase 回复 更多评论
2006-12-28 12:22 by
1)打印出被删除的元素, 很简单
struct MyPred
{
bool operator()(int n) const
{
if(n%2 == 0) {cout << "Erasing " << n << endl; return true; }
else return false;
}
};
vector<int> v;
vector_erase_if(v, MyPred());
2)list提供了remove方法,但是set,map没有
(实际上这几行代码都是从STL的list源码中抄出来的,主要用于set 和map);
# re: [STL] 循环中erase 回复 更多评论
2007-02-14 15:49 by
方法2是错的!应该是(ri++).base().
给出的循环删除方法太低效!
# re: [STL] 循环中erase 回复 更多评论
2012-10-25 20:33 by
@楚竹荷叶
我也发现了,vector如果只有一个值,逆向删除就会抛出异常,正向删除不会