@specsoftdev live:.cid.8e17e9b93cabb607 specsoftdev@gmail.com
std::ranges::none_of
Актуально для C++23.

#include <algorithm>
Актуально на 2025-05-08.


Define overload #1
template<input_iterator I, sentinel_for<I> S, class Proj = identity, indirect_unary_predicate<projected<I, Proj>> Pred>
constexpr bool ranges::none_of(I first, S last, Pred pred, Proj proj = {});

Вернёт true, если ни один элемент из диапазона [first, last], не удовлетворяет условия предиката "pred".
Иначе, вернёт false.
Example, possible implementation
Define overload #2
template<input_range R, class Proj = identity, indirect_unary_predicate<projected<iterator_t<R>, Proj>> Pred>
constexpr bool ranges::none_of(R&& r, Pred pred, Proj proj = {});

Вернёт true, если ни один элемент из диапазона "r", не удовлетворяет условия предиката "pred".
Иначе, вернёт false.
Example, possible implementation

Notes

  • Если входящая последовательность пустат, будет возвращено значение true.
  • Алгоритм завершит работу как только встретится первый элемент, для которого предикат возвратит true.
  • Перебор элементов начинается с начала последовательности.




Examples


Example 1:
#include <iostream>
#include <algorithm>

namespace ranges = std::ranges;

int main()
{
    auto list = {'D', 'i', 'R', 'f'};

    auto no_upper = ranges::none_of(std::begin(list), std::end(list), [](unsigned char s) { return std::isupper(s); });
    auto no_lower = ranges::none_of(std::begin(list), std::end(list), [](unsigned char s) { return std::islower(s); });
    auto no_digit = ranges::none_of(std::begin(list), std::end(list), [](unsigned char s) { return std::isdigit(s); });

    std::cout << std::boolalpha;
    std::cout << no_upper << std::endl;
    std::cout << no_lower << std::endl;
    std::cout << no_digit << std::endl;
}

false
false
true





Changelog

C++20
Введён в стандарт.


See also

TODO

This page was last modified on 2025-05-08