Espacios de nombres
Variantes
Acciones

std::ranges::starts_with

De cppreference.com
< cpp‎ | algorithm‎ | ranges
 
 
Biblioteca de algoritmos
Políticas de ejecución (C++17)
Operaciones de secuencia no modificantes
(C++11)(C++11)(C++11)
(C++17)
Operaciones de secuencia modificantes
Operaciones en almacenamiento no inicializado
Operaciones de partición
Operaciones de ordenación
(C++11)
Operaciones de búsqueda binaria
Operaciones de conjuntos (en rangos ordenados)
Operaciones de pila
(C++11)
Operaciones mínimo/máximo
(C++11)
(C++17)
Permutaciones
Operaciones numéricas
Bibliotecas C
 
Algoritmos restringidos
Operaciones de secuencia no modificantes
Operaciones de secuencia modificantes
Operaciones en almacenamiento sin inicializar
Operaciones de partición
Operaciones de ordenamiento
Operaciones de búsqueda binaria
Operaciones de conjuntos (en rangos ordenados)
Operaciones de montículo/montón
Operaciones de mínimo/máximo
Permutaciones
 
Definido en el archivo de encabezado <algorithm>
Signatura de la llamada
template< std::input_iterator I1, std::sentinel_for<I1> S1,

          std::input_iterator I2, std::sentinel_for<I2> S2,
          class Pred = ranges::equal_to,
          class Proj1 = std::identity, class Proj2 = std::identity >
requires std::indirectly_comparable<I1, I2, Pred, Proj1, Proj2>
constexpr bool starts_with( I1 first1, S1 last1, I2 first2, S2 last2,

                            Pred pred = {}, Proj1 proj1 = {}, Proj2 proj2 = {} );
(1) (desde C++23)
template< ranges::input_range R1, ranges::input_range R2,

          class Pred = ranges::equal_to,
          class Proj1 = std::identity, class Proj2 = std::identity >
requires std::indirectly_comparable<ranges::iterator_t<R1>,
                                    ranges::iterator_t<R2>,
                                    Pred, Proj1, Proj2>
constexpr bool starts_with( R1&& r1, R2&& r2,

                            Pred pred = {}, Proj1 proj1 = {}, Proj2 proj2 = {} );
(2) (desde C++23)

Comprueba si el segundo rango coincide con el prefijo del primer rango.

1) Sea N1 y N2 denote el tamaño de los rangos [first1, last1) y [first2, last2) respectivamente. Si N1 < N2, devuelve false. De lo contrario, devuelve true solo si cada elemento en el rango [first2, last2) es igual al elemento correspondiente en [first1, first1 + N2). La comparación se hace aplicando el predicado binario pred a los elementos en dos rangos proyectados por proj1 y proj2 respectivamente.
2) Igual que (1), pero usa r1 y r2 como los rangos fuente, como si usara ranges::begin(r1) como first1, ranges:begin(r2) como first2, ranges::end(r1) como last1, y ranges::end(r2) como last2.

Las entidades similares a funciones descritas en esta página son niebloids, es decir:

En la práctica, pueden implementarse como objetos función o con extensiones de compilador especiales.

Contenido

[editar] Parámetros

first1, last1 - El rango de los elementos a examinar.
r1 - El rango de los elementos a examinar.
first2, last2 - El rango de los elementos que se utilizarán como prefijo.
r2 - El rango de los elementos que se utilizarán como prefijo.
pred - El predicado binario que compara los elementos proyectados.
proj1 - La proyección a aplicar a los elementos del rango a examinar.
proj2 - La proyección a aplicar a los elementos del rango a utilizar como prefijo.

[editar] Valor de retorno

true si el segundo rango coincide con el prefijo del primer rango, false de lo contrario.

[editar] Complejidad

Lineal: a lo sumo min(N1, N2) aplicaciones del predicado y ambas proyecciones.

[editar] Posible implementación

struct starts_with_fn
{
    template<std::input_iterator I1, std::sentinel_for<I1> S1,
             std::input_iterator I2, std::sentinel_for<I2> S2,
             class Pred = ranges::equal_to,
             class Proj1 = std::identity, class Proj2 = std::identity>
      requires std::indirectly_comparable<I1, I2, Pred, Proj1, Proj2>
    constexpr bool operator()(I1 first1, S1 last1, I2 first2, S2 last2,
                              Pred pred = {}, Proj1 proj1 = {}, Proj2 proj2 = {}) const
    {
        return ranges::mismatch(std::move(first1), last1, std::move(first2), last2,
                                std::move(pred), std::move(proj1), std::move(proj2)
                               ).in2 == last2;
    }
 
    template<ranges::input_range R1, ranges::input_range R2,
             class Pred = ranges::equal_to,
             class Proj1 = std::identity, class Proj2 = std::identity>
      requires std::indirectly_comparable<ranges::iterator_t<R1>,
                                          ranges::iterator_t<R2>,
                                          Pred, Proj1, Proj2>
    constexpr bool operator()(R1&& r1, R2&& r2,
                              Pred pred = {}, Proj1 proj1 = {}, Proj2 proj2 = {}) const
    {
        return (*this)(ranges::begin(r1), ranges::end(r1),
                       ranges::begin(r2), ranges::end(r2),
                       std::move(pred), std::move(proj1), std::move(proj2));
    }
};
 
inline constexpr starts_with_fn starts_with{};

[editar] Notas

Macro de Prueba de característica Valor Estándar Comentario
__cpp_lib_ranges_starts_ends_with 202106L (C++23) std::ranges::starts_with, std::ranges::ends_with

[editar] Ejemplo

#include <string_view>
#include <algorithm>
#include <iostream>
#include <ranges>
 
int main()
{
    using namespace std::literals;
 
    constexpr auto ascii_upper = [](char8_t c)
    {
        return u8'a' <= c && c <= u8'z' ? static_cast<char8_t>(c + u8'A' - u8'a') : c;
    };
 
    constexpr auto cmp_ignore_case = [=](char8_t x, char8_t y)
    {
        return ascii_upper(x) == ascii_upper(y);
    };
 
    static_assert(std::ranges::starts_with("const_cast", "const"sv));
    static_assert(std::ranges::starts_with("constexpr", "const"sv));
    static_assert(!std::ranges::starts_with("volatile", "const"sv));
 
    std::cout << std::boolalpha
              << std::ranges::starts_with(u8"Constantinopolis", u8"constant"sv,
                                          {}, ascii_upper, ascii_upper) << ' '
              << std::ranges::starts_with(u8"Istanbul", u8"constant"sv,
                                          {}, ascii_upper, ascii_upper) << ' '
              << std::ranges::starts_with(u8"Metropolis", u8"metro"sv,
                                          cmp_ignore_case) << ' '
              << std::ranges::starts_with(u8"Acropolis", u8"metro"sv,
                                          cmp_ignore_case) << '\n';
 
    constexpr static auto v = { 1, 3, 5, 7, 9 };
    constexpr auto odd = [](int x) { return x % 2; };
    static_assert( std::ranges::starts_with( v, std::views::iota(1)
                                              | std::views::filter(odd)
                                              | std::views::take(3) ) );
}

Salida:

true false true false

[editar] Véase también

Verifica si un rango termina con otro rango.
(niebloid) [editar]
Encuentra la primera posición donde dos rangos difieren.
(niebloid) [editar]
Comprueba si la cadena comienza con el prefijo dado.
(función miembro pública de std::basic_string) [editar]
Comprueba si la vista sobre cadena comienza con un prefijo dado.
(función miembro pública de std::basic_string_view<CharT,Traits>) [editar]