Condividi tramite


count_if

Restituisce il numero di elementi in un intervallo dei valori soddisfano una condizione specificata.

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

Parametri

  • _First
    Un iteratore di input destinato alla posizione del primo elemento nell'intervallo da rilevare.

  • _Last
    Un iteratore di input destinato alla posizione una dopo l'elemento finale nell'intervallo da rilevare.

  • _Pred
    Oggetto definito dall'utente di funzione di predicato che definisce la condizione soddisfatta se un elemento venga conteggiato.Un predicato accetta un solo argomento e restituisce true o false.

Valore restituito

Il numero di elementi che soddisfano la condizione specificata dal predicato.

Note

Questa funzione modello è una generalizzazione l'algoritmo conteggio, sostituendo il predicato “uguale a un valore specifico" con il predicato.

Esempio

// 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;
}
  

Requisiti

intestazione: <algorithm>

Spazio dei nomi: deviazione standard

Vedere anche

Riferimenti

count_if (STL Samples)

Libreria di modelli standard