@specsoftdev live:.cid.8e17e9b93cabb607 specsoftdev@gmail.com
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
TODO
C++23
TODO
C++20
TODO
C++17
TODO
C++14
TODO
C++11
TODO


See also

TODO

This page was last modified on 2024-03-23