std::remove_copy_if
Актуально для C++23.
#include <algorithm>
Актуально на 2024-03-23.
Define overload #1
template<class InputIterator, class OutputIterator, class Predicate> constexpr OutputIterator remove_copy_if(InputIterator first, InputIterator last, OutputIterator result, Predicate pred);
Копирует элементы из диапазона [first, last] которые не эквивалентны "value".
Эквивалентность проверяется с помощью унарного предиката "pred".
Алгоритм стабилен, т.е. порядок элементов остаётся прежним.
Вернёт result увеличенный на количество скопированных элементов.
Example, possible implementation
Define overload #2
template<class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2, class Predicate> ForwardIterator2 remove_copy_if(ExecutionPolicy&& exec, ForwardIterator1 first, ForwardIterator1 last, ForwardIterator2 result, Predicate pred);
TODO
Example, possible implementation
Examples
Example 1:
#include <iostream> #include <algorithm> #include <vector> int main() { std::vector<int> v4 {1,2,3,4,5}; std::vector<int> result(v4.size()); auto end = std::remove_copy_if(std::begin(v4), std::end(v4), std::begin(result), [](auto ch) { return ch==1; }); for (auto it = std::begin(result); it != end; ++it) { std::cout << *it << std::endl; } return 0; }
2 3 4 5
Changelog
C++26
TODOC++23
TODOC++20
TODOC++17
TODOC++14
TODOC++11
TODOSee also
TODO
This page was last modified on 2024-03-23