STL删除list元素

来源:互联网 发布:什么是淘宝同步单 编辑:程序博客网 时间:2024/05/18 03:04
list.push_back(2);
mylist.push_back(3);
mylist.push_back(1);
mylist.push_back(2);
  
// 删除元素2
  
// 方式一
  
mylist.remove(2);
  
// 方式二
  
mylist.erase(remove_if(mylist.begin(), mylist.end(), not1(bind2nd(modulus<int>(), 2))), mylist.end());
  
// 方式三
  
list<int>::iterator Iter;
list<int>::iterator EndIter = mylist.end();
for(Iter = mylist.begin(); Iter != EndIter; )
    {
        if(*Iter == 2)
            Iter = mylist.erase(Iter);
        else
            Iter++;
    }

打印出结果

 

1
2
3
4
5
6
list<int>::iterator Iter;
list<int>::iterator EndIter = mylist.end();
for(Iter = mylist.begin(); Iter != EndIter; Iter++)
{
    cout << *Iter << endl;
}

三种方式的速度比(数值越小速度越快)
1 : 1.63 : 1.17
注:这里的速度比较是简单的、粗糙的比较。