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

std::list::remove, std::list::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); // 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

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

удаляет элементы, удовлетворяющие определенным критериям
Оригинал:
removes elements satisfying specific criteria
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

(шаблон функции) [править]