std::find_end
Актуально для C++23.
#include <algorithm>
Актуально на 2024-02-19.
Define overload #1
template<class Iter1, class Iter2> constexpr Iter1 find_end(Iter1 first, Iter1 last, Iter2 s_first, Iter2 s_last);
Ищет в диапазоне [first, last], последнюю последовательность [s_first, s_last].
Вернёт итератор на первый элемент, или last, если нет совпадений.
В большинстве реализаций(GCC), поиск выполняется с конца последовательностей, используя std::reverse_iterator, если итератор поддерживает такую операцию.
Example, possible implementation
Define overload #2
template <class ExecutionPolicy, class ForwardIter1, class ForwardIter2> ForwardIter1 find_end(ExecutionPolicy&& exec, ForwardIter1 first, ForwardIter1 last, ForwardIter2 s_first, ForwardIter2 s_last);
Example, possible implementation
Define overload #3
template<class Iter1, class Iter2, class BiPred> constexpr Iter1 find_end(Iter1 first, Iter1 last, Iter2 s_first, Iter2 s_last, BinaryPred pred);
Ищет в диапазоне [first, last], последнюю последовательность [s_first, s_last].
Для сравнения элементов применяется предикат pred.
Вернёт итератор на первый элемент, или last, если нет совпадений.
В большинстве реализаций(GCC), поиск выполняется с конца последовательностей, используя std::reverse_iterator, если итератор поддерживает такую операцию.
Example, possible implementation
Define overload #4
template <class ExecutionPolicy, class ForwardIterator1, class ForwardIterator2, class BinaryPredicate> ForwardIterator1 find_end(ExecutionPolicy&& exec, ForwardIterator1 first, ForwardIterator1 last, ForwardIterator2 s_first, ForwardIterator2 s_last, BinaryPredicate pred);
Example, possible implementation
Examples
Example 1:
#include <iostream> #include <algorithm> #include <vector> #include <string> int main() { std::string str{"substr1_substr2_substr3"}; std::string s_str{"substr"}; auto find_it = std::find_end(std::begin(str), std::end(str), std::begin(s_str), std::end(s_str)); if (find_it != std::end(str)) { std::cout << std::string_view(find_it, std::end(str)) << std::endl; } else { std::cout << "No matches." << std::endl; } return 0; }
substr3
Example 2:
#include <iostream> #include <algorithm> #include <vector> #include <string> int main() { std::string str{"substr1_substr2_substr3"}; std::string s_str{"substr"}; const auto pred = [](char str, char s_str) { return s_str == str; }; auto find_it = std::find_end(std::begin(str), std::end(str), std::begin(s_str), std::end(s_str), pred); if (find_it != std::end(str)) { std::cout << std::string_view(find_it, std::end(str)) << std::endl; } else { std::cout << "No matches." << std::endl; } return 0; }
substr3
Changelog
C++26
TODOC++23
TODOC++20
TODOC++17
TODOC++14
TODOC++11
TODOSee also
TODO
This page was last modified on 2024-02-19