Mega Code Archive

 
Categories / C++ / List
 

Good way and bad way to remove elements in a list

/* The following code example is taken from the book  * "The C++ Standard Library - A Tutorial and Reference"  * by Nicolai M. Josuttis, Addison-Wesley, 1999  *  * (C) Copyright Nicolai M. Josuttis 1999.  * Permission to copy, use, modify, sell and distribute this software  * is granted provided this copyright notice appears in all copies.  * This software is provided "as is" without express or implied  * warranty, and with no claim as to its suitability for any purpose.  */ #include <iostream> #include <list> #include <algorithm> using namespace std; int main() {     list<int> coll;     // insert elements from 6 to 1 and 1 to 6     for (int i=1; i<=6; ++i) {         coll.push_front(i);         coll.push_back(i);     }     // remove all elements with value 3     // - poor performance     coll.erase (remove(coll.begin(),coll.end(),                        3),                 coll.end());     // remove all elements with value 4     // - good performance     coll.remove (4); }