Partager via


count_if

Retourne le nombre d'éléments dans une plage dont les valeurs remplissent une condition spécifiée.

template<class InputIterator, class Predicate>
   typename iterator_traits<InputIterator>::difference_type count_if(
      InputIterator _First, 
      InputIterator _Last,
      Predicate _Pred
   );

Paramètres

  • _First
    Un itérateur d'entrée adressant la position du premier élément dans la plage à rechercher.

  • _Last
    Un itérateur d'entrée adressant une position au delà de le dernier élément dans la plage à rechercher.

  • _Pred
    Objet défini par l'utilisateur de fonction de prédicat qui définit la condition à satisfaire si un élément doit avoir compté.Un attribut prend un argument unique et retourne true ou false.

Valeur de retour

Le nombre d'éléments qui remplissent la condition a spécifié par l'attribut.

Notes

Cette fonction de modèle est une généralisation de l'algorithme nombre, en remplaçant l'attribut « est égal à une valeur spécifique » par tout attribut.

Exemple

// alg_count_if.cpp
// compile with: /EHsc
#include <vector>
#include <algorithm>
#include <iostream>

bool greater10(int value)
{
    return value >10;
}

int main()
{
    using namespace std;
    vector<int> v1;
    vector<int>::iterator Iter;

    v1.push_back(10);
    v1.push_back(20);
    v1.push_back(10);
    v1.push_back(40);
    v1.push_back(10);

    cout << "v1 = ( ";
    for (Iter = v1.begin(); Iter != v1.end(); Iter++)
        cout << *Iter << " ";
    cout << ")" << endl;

    vector<int>::iterator::difference_type result1;
    result1 = count_if(v1.begin(), v1.end(), greater10);
    cout << "The number of elements in v1 greater than 10 is: "
         << result1 << "." << endl;
}
  

Configuration requise

en-tête : <algorithm>

l'espace de noms : DST

Voir aussi

Référence

count_if (STL Samples)

Modèles Standard