Namespaces
Variants

std::ranges:: contains, std::ranges:: contains_subrange

From cppreference.net
Algorithm library
Constrained algorithms and algorithms on ranges (C++20)
Constrained algorithms, e.g. ranges::copy , ranges::sort , ...
Execution policies (C++17)
Non-modifying sequence operations
Batch operations
(C++17)
Search operations
Modifying sequence operations
Copy operations
(C++11)
(C++11)
Swap operations
Transformation operations
Generation operations
Removing operations
Order-changing operations
(until C++17) (C++11)
(C++20) (C++20)
Sampling operations
(C++17)

Sorting and related operations
Partitioning operations
Sorting operations
Binary search operations
(on partitioned ranges)
Set operations (on sorted ranges)
Merge operations (on sorted ranges)
Heap operations
Minimum/maximum operations
Lexicographical comparison operations
Permutation operations
C library
Numeric operations
Operations on uninitialized memory
Constrained algorithms
All names in this menu belong to namespace std::ranges
Non-modifying sequence operations
Modifying sequence operations
Partitioning operations
Sorting operations
Binary search operations (on sorted ranges)
Set operations (on sorted ranges)
Heap operations
Minimum/maximum operations
Permutation operations
Fold operations
Operations on uninitialized storage
Return types
Défini dans l'en-tête <algorithm>
Signature d'appel
(1)
template < std:: input_iterator I, std:: sentinel_for < I > S,

class T,
class Proj = std:: identity >
requires std:: indirect_binary_predicate
< ranges:: equal_to , std :: projected < I, Proj > , const T * >

constexpr bool contains ( I first, S last, const T & value, Proj proj = { } ) ;
(depuis C++23)
(jusqu'à C++26)
template < std:: input_iterator I, std:: sentinel_for < I > S,

class Proj = std:: identity ,
class T = std :: projected_value_t < I, Proj > >
requires std:: indirect_binary_predicate
< ranges:: equal_to , std :: projected < I, Proj > , const T * >

constexpr bool contains ( I first, S last, const T & value, Proj proj = { } ) ;
(depuis C++26)
(2)
template < ranges:: input_range R,

class T,
class Proj = std:: identity >
requires std:: indirect_binary_predicate
< ranges:: equal_to ,
std :: projected < ranges:: iterator_t < R > , Proj > , const T * >

constexpr bool contains ( R && r, const T & value, Proj proj = { } ) ;
(depuis C++23)
(jusqu'à C++26)
template < ranges:: input_range R,

class Proj = std:: identity ,
class T = std :: projected_value_t < ranges:: iterator_t < R > , Proj > >
requires std:: indirect_binary_predicate
< ranges:: equal_to ,
std :: projected < ranges:: iterator_t < R > , Proj > , const T * >

constexpr bool contains ( R && r, const T & value, Proj proj = { } ) ;
(depuis C++26)
template < std:: forward_iterator I1, std:: sentinel_for < I1 > S1,

std:: forward_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 contains_subrange ( I1 first1, S1 last1, I2 first2, S2 last2,
Pred pred = { } ,

Proj1 proj1 = { } , Proj2 proj2 = { } ) ;
(3) (depuis C++23)
template < ranges:: forward_range R1, ranges:: forward_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 contains_subrange ( R1 && r1, R2 && r2, Pred pred = { } ,

Proj1 proj1 = { } , Proj2 proj2 = { } ) ;
(4) (depuis C++23)
1,2) Vérifie si une plage donnée contient ou non la valeur value .
1) La plage source est [ first , last ) .
2) La plage source est [ ranges:: begin ( r ) , ranges:: end ( r ) ) .
3) Vérifie si une plage donnée est une sous-plage d'une autre plage.
3) La première plage source est [ first1 , last1 ) , et la deuxième plage source est [ first2 , last2 ) .
4) La première plage source est [ ranges:: begin ( r1 ) , ranges:: end ( r1 ) ) , et la deuxième plage source est [ ranges:: begin ( r2 ) , ranges:: end ( r2 ) ) .

Les entités de type fonction décrites sur cette page sont des objets fonction d'algorithme (informellement appelés niebloids ), c'est-à-dire :

Table des matières

Paramètres

first, last - la paire itérateur-sentinelle définissant la plage des éléments à examiner
r - la plage des éléments à examiner
value - valeur à comparer aux éléments
pred - prédicat à appliquer aux éléments projetés
proj - projection à appliquer aux éléments

Valeur de retour

1) ranges:: find ( std :: move ( first ) , last, value, proj ) ! = last
**Note:** Le code C++ n'a pas été traduit conformément aux instructions, car il se trouve dans des balises spécifiques au code et contient des termes techniques C++ qui doivent rester en anglais. Seul le texte "1)" a été conservé tel quel, car il s'agit d'un numéro qui ne nécessite pas de traduction.
2) ranges:: find ( std :: move ( ranges:: begin ( r ) ) , ranges:: end ( r ) , valeur, proj ) ! = ranges:: end ( r )
3) first2 == last2 || ! ranges:: search ( first1, last1, first2, last2, pred, proj1, proj2 ) . empty ( )
4) ranges:: begin ( r2 ) == ranges:: end ( r2 ) ||
! ranges:: search ( ranges:: begin ( r1 ) , ranges:: end ( r1 ) ,
ranges:: begin ( r2 ) , ranges:: end ( r2 ) , pred, proj1, proj2 ) . empty ( )

Complexité

1) Au maximum ranges:: distance ( first, last ) comparaisons.
2) Au maximum ranges:: distance ( r ) comparaisons.
3) Au maximum ranges:: distance ( first1, last1 ) * ranges:: distance ( first2, last2 ) comparaisons.
4) Au maximum ranges:: distance ( r1 ) * ranges:: distance ( r2 ) comparaisons.

Notes

En C++20, on peut implémenter une fonction contains avec ranges:: find ( haystack, needle ) ! = ranges:: end ( haystack ) ou une fonction contains_subrange avec ! ranges:: search ( haystack, needle ) . empty ( ) .

ranges::contains_subrange , comme ranges::search , et contrairement à std::search , ne prend pas en charge les searchers (tels que std::boyer_moore_searcher ).

Macro de test de fonctionnalité Valeur Std Fonctionnalité
__cpp_lib_ranges_contains 202207L (C++23) ranges::contains et ranges::contains_subrange
__cpp_lib_algorithm_default_value_type 202403L (C++26) Initialisation par liste pour les algorithmes ( 1,2 )

Implémentation possible

contient (1,2)
struct __contains_fn
{
    template<std::input_iterator I, std::sentinel_for<I> S,
             class Proj = std::identity,
             class T = std::projected_value_t<I, Proj>>
    requires std::indirect_binary_predicate<ranges::equal_to, std::projected<I, Proj>,
                                            const T*>
    constexpr bool operator()(I first, S last, const T& value, Proj proj = {}) const
    {
        return ranges::find(std::move(first), last, value, proj) != last;
    }
    template<ranges::input_range R,
             class Proj = std::identity,
             class T = std::projected_value_t<ranges::iterator_t<R>, Proj>>
    requires std::indirect_binary_predicate<ranges::equal_to,
                                            std::projected<ranges::iterator_t<R>, Proj>,
                                            const T*>
    constexpr bool operator()(R&& r, const T& value, Proj proj = {}) const
    {
        return ranges::find(std::move(ranges::begin(r)),
                            ranges::end(r), value, proj) != ranges::end(r);
    }
};
inline constexpr __contains_fn contains{};
contient_sous_plage (3,4)
struct __contains_subrange_fn
{
    template<std::forward_iterator I1, std::sentinel_for<I1> S1,
             std::forward_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 (first2 == last2) ||
                   !ranges::search(first1, last1, first2, last2,
                                   pred, proj1, proj2).empty();
    }
    template<ranges::forward_range R1, ranges::forward_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 (first2 == last2) ||
                   !ranges::search(ranges::begin(r1), ranges::end(r1),
                                   ranges::begin(r2), ranges::end(r2),
                                   pred, proj1, proj2).empty();
    }
};
inline constexpr __contains_subrange_fn contains_subrange{};

Exemple

#include <algorithm>
#include <array>
#include <complex>
namespace ranges = std::ranges;
int main()
{
    constexpr auto haystack = std::array{3, 1, 4, 1, 5};
    constexpr auto needle = std::array{1, 4, 1};
    constexpr auto bodkin = std::array{2, 5, 2};
    static_assert
    (
        ranges::contains(haystack, 4) &&
       !ranges::contains(haystack, 6) &&
        ranges::contains_subrange(haystack, needle) &&
       !ranges::contains_subrange(haystack, bodkin)
    );
    constexpr std::array<std::complex<double>, 3> nums{{{1, 2}, {3, 4}, {5, 6}}};
    #ifdef __cpp_lib_algorithm_default_value_type
        static_assert(ranges::contains(nums, {3, 4}));
    #else
        static_assert(ranges::contains(nums, std::complex<double>{3, 4}));
    #endif
}

Voir aussi

trouve le premier élément satisfaisant des critères spécifiques
(objet fonction algorithme)
recherche la première occurrence d'une plage d'éléments
(objet fonction algorithme)
détermine si un élément existe dans une plage partiellement ordonnée
(objet fonction algorithme)
retourne true si une séquence est une sous-séquence d'une autre
(objet fonction algorithme)
vérifie si un prédicat est true pour tous, certains ou aucun des éléments d'une plage
(objet fonction algorithme)