Namespaces
Variants

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

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

Находит последний символ, не равный ни одному из символов в заданной последовательности. Поиск рассматривает только интервал [ 0 , pos ] .

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

Содержание

Параметры

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

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

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

Сложность

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

Пример

#include <string_view>
using std::operator""sv;
int main()
{
    static_assert(1 == "BCDEF"sv.find_last_not_of("DEF"));
                    //   ^
    static_assert(2 == "BCDEFG"sv.find_last_not_of("EFG", 3));
                    //    ^
    static_assert(2 == "ABBA"sv.find_last_not_of('A'));
                    //    ^
    static_assert(1 == "ABBA"sv.find_last_not_of('A', 1));
                    //   ^
}

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

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