std::ranges::copy_if
Актуально для C++26.
#include <algorithm>
Актуально на 2025-06-15.
Define overload #1
template<input_iterator I, sentinel_for<I> S,
weakly_incrementable O,
class Proj = identity,
indirect_unary_predicate<projected<I, Proj>> Pred>
requires indirectly_copyable<I, O>
constexpr ranges::copy_if_result<I, O>
copy_if(I first, S last, O result, Pred pred, Proj proj = {});
Копирует элементы из диапазона [first, last] в result;
first, last - пара iterator-sentinel;
Example, possible implementation
Define overload #2
template<input_range R, weakly_incrementable O,
class Proj = identity,
indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
requires indirectly_copyable<iterator_t<R>, O>
constexpr ranges::copy_if_result<borrowed_iterator_t<R>, O>
copy_if(R&& r, O result, Pred pred, Proj proj = {});
Копирует элементы из диапазона r в result;
r - объект, удовлетворяющий требования концепта input_range;
Example, possible implementation
[general_parameters]
result - любой объект, удовлетворяющий требования концепта weakly_incrementable. Алгоритм не осуществляет проверку переполнения буфера. Пользователь должен позаботиться о том, чтобы памяти на которую ссылается result, хватило для записи всех элементов.
pred - унарный предикат, любой "callable" объект, используемый для сравнения элементов.
proj - унарный предикат, любой "callable" объект. Используемый для преобразования элемента перед вызовом "pred".
[/general_parameters]
Возвращаемое значение
Вернёт два итератора, указывающих на концы диапазонов.
Examples
Example 1:
#include <algorithm>
#include <iostream>
#include <string>
#include <vector>
namespace ranges = std::ranges;
int main()
{
std::string copied = "wor1d1";
std::vector<char> result {'h', 'e', 'l', 'l', 'o', ' '};
const auto pred ([](unsigned char c) {
return !std::isdigit(c);
});
ranges::copy_if(copied, std::back_inserter(result), pred);
for (auto c : result)
std::cout << c;
std::cout << std::endl;
}
hello word
Changelog
C++20
Введён в стандарт.See also
TODO
This page was last modified on 2025-06-15