std::find_if_not
Актуально для C++23.
#include <algorithm>
Актуально на 2024-02-17.
Define overload #1
template<class IIter, class Predicate> constexpr IIter find_if_not(IIter first, IIter last, Predicate pred);
Ищет в заданном диапазоне [first, last] первый элемент, не удовлетворяющей предикат pred.
Вернёт итератор на первый найденный элемент, или last, если такого элемента не нашлось.
Поиск выполняется последовательным перебором, начиная с позиции "first".
Example, possible implementation
Define overload #2
template <class ExecutionPolicy, class ForwardIterator, class Predicate> ForwardIterator find_if_not(ExecutionPolicy&& exec, ForwardIterator first, ForwardIterator last, Predicate pred);
Example, possible implementation
Examples
Example 1:
#include <iostream> #include <string> #include <algorithm> #include <cctype> int main() { const auto pred = [](auto s) { return ::isalpha(static_cast<unsigned char>(s)); }; std::string str = "hello_world!"; auto find_it = std::find_if_not(std::begin(str), std::end(str), pred); if (find_it != std::end(str)) { std::cout << std::string_view(find_it, std::end(str)) << std::endl; } else { std::cout << "Одни буквы... ." << std::endl; } return 0; }
_world!
Changelog
See also
TODO
This page was last modified on 2024-02-17