Partilhar via


count_if

Retorna o número de elementos em um intervalo cujos valores satisfaçam uma condição especificada.

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

Parâmetros

  • _First
    Um iterador de entrada que trata a posição do primeiro elemento no intervalo ser pesquisada.

  • _Last
    Um iterador de entrada que trata a posição uma após o elemento final no intervalo ser pesquisada.

  • _Pred
    Objeto definido pelo usuário da função de predicado que define a condição seja satisfeita se um elemento deve contados.Um predicado leva o único argumento e retorna true ou false.

Valor de retorno

O número de elementos que satisfazem a condição especificado por predicado.

Comentários

Esta função do modelo é uma generalização do algoritmo contagem, substituindo o predicado “equals um determinado valor” com qualquer predicado.

Exemplo

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

Requisitos

Cabeçalho: <algorithm>

namespace: STD

Consulte também

Referência

count_if (STL Samples)

Standard Template Library