std::list::remove, remove_if

来自cppreference.com
< cpp‎ | container‎ | list
void remove( const T& value );
template< class UnaryPredicate >
void remove_if( UnaryPredicate p );

移除所有满足特定标准的元素。第一版本移除所有等于 value 的元素,第二版本移除所有谓词 p 对它返回 true 的元素。

目录

[编辑] 参数

value - 要移除的元素的值
p - 是否应移除该元素则返回 true 的一元谓词。

谓词函数签名应等价于如下者:

 bool pred(const Type &a);

签名不必拥有 const & ,但函数必须不修改传递给它的对象。
类型 Type 必须使得 list<T,Allocator>::const_iterator 类型对象能在解引用后隐式转换到 Type 。 ​

[编辑] 返回值

(无)

[编辑] 复杂度

与容器大小成线性

[编辑] 示例

#include <list>
#include <iostream>
 
int main()
{
    std::list<int> l = { 1,100,2,3,10,1,11,-1,12 };
 
    l.remove(1); // 移除两个等于 1 的元素
    l.remove_if([](int n){ return n > 10; }); // 移除全部大于 10 的元素
 
    for (int n : l) {
        std::cout << n << ' '; 
    }
    std::cout << '\n';
}

输出:

2 3 10 -1

[编辑] 参阅

移除满足特定标准的元素
(函数模板) [编辑]