Namespaces
Variants

std::basic_string_view<CharT,Traits>:: rfind

From cppreference.net
constexpr size_type rfind ( basic_string_view v, size_type pos = npos ) const noexcept ;
(1) (начиная с C++17)
constexpr size_type rfind ( CharT ch, size_type pos = npos ) const noexcept ;
(2) (начиная с C++17)
constexpr size_type rfind ( const CharT * s, size_type pos, size_type count ) const ;
(3) (начиная с C++17)
constexpr size_type rfind ( const CharT * s, size_type pos = npos ) const ;
(4) (начиная с C++17)

Находит последнюю подстроку, равную заданной последовательности символов. Поиск начинается с позиции pos и выполняется справа налево (таким образом, найденная подстрока, если таковая имеется, не может начинаться в позиции, следующей за pos ). Если в качестве pos передано значение npos или любое значение не меньшее, чем size() - 1 , будет выполнен поиск по всей строке.

1) Находит последнее вхождение v в данном представлении, начиная с позиции pos .
2) Эквивалентно rfind ( basic_string_view ( std:: addressof ( ch ) , 1 ) , pos ) .
3) Эквивалентно rfind ( basic_string_view ( s, count ) , pos ) .
4) Эквивалентно rfind ( basic_string_view ( s ) , pos ) .

Содержание

Параметры

v - представление для поиска
pos - позиция, с которой начинать поиск
count - длина подстроки для поиска
s - указатель на строку символов для поиска
ch - символ для поиска

Возвращаемое значение

Позиция первого символа найденной подстроки или npos если такая подстрока не найдена.

Сложность

O( size() * v. size() ) в худшем случае.

Пример

#include <string_view>
int main()
{
    using namespace std::literals;
    constexpr auto N = std::string_view::npos;
    static_assert(true
        && (6 == "AB AB AB"sv.rfind("AB"))
        && (6 == "AB AB AB"sv.rfind("ABCD", N, 2))
        && (3 == "AB AB AB"sv.rfind("AB", 5))
        && (0 == "AB CD EF"sv.rfind("AB", 0))
        && (2 == "B AB AB "sv.rfind("AB", 2))
        && (N == "B AB AB "sv.rfind("AB", 1))
        && (5 == "B AB AB "sv.rfind('A'))
        && (4 == "AB AB AB"sv.rfind('B', 4))
        && (N == "AB AB AB"sv.rfind('C'))
    );
}

Смотрите также

найти символы в представлении
(публичная функция-член)
найти первое вхождение символов
(публичная функция-член)
найти последнее вхождение символов
(публичная функция-член)
найти первое отсутствие символов
(публичная функция-член)
найти последнее отсутствие символов
(публичная функция-член)
найти последнее вхождение подстроки
(публичная функция-член std::basic_string<CharT,Traits,Allocator> )