Пространства имён
Варианты
Действия

std::forward_list::remove, std::forward_list::remove_if

Материал из cppreference.com
 
 
 
 
void remove( const T& value );
(начиная с C++11)
template< class UnaryPredicate >
void remove_if( UnaryPredicate p );
(начиная с C++11)

Удаляет все элементы, удовлетворяющие определенному условию. Первый вариант удаляет все элементы, равные value, второй вариант удаляет все элементы, для которых предикат p возвращает true.


Содержание

[править] Параметры

value значение удаляемых элементов
p унарный предикат, который возвращает​true если элемент должен быть удален.

Определение функции предиката должно быть эквивалентно следующему:

 bool pred(const Type &a);

Присутствие const & в определении не обязательно, но функция не должна модифицировать передаваемые ей объекты.
Тип Type должен быть таков, что объект типа forward_list<T,Allocator>::const_iterator может быть разыменован и затем неявно преобразован в Type. ​

[править] Возвращаемое значение

(Нет)

[править] Сложность

Линейно от размера контейнера

[править] Пример

#include <forward_list>
#include <iostream>
 
int main()
{
    std::forward_list<int> l = { 1,100,2,3,10,1,11,-1,12 };
 
    l.remove(1); // remove both elements equal to 1
    l.remove_if([](int n){ return n > 10; }); // remove all elements greater than 10
 
    for (int n : l) {
        std::cout << n << ' ';
    }
    std::cout << '\n';
}

Вывод:

2 3 10 -1

[править] См. также

удаляет элементы, соответствующие определённым критериям
(шаблон функции) [править]