Partilhar via


count_if

Retorna o número de elementos em um intervalo cujos valores atendem a 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 pesquisado.

  • _Last
    Um iterador de entrada que trata a posição uma depois do elemento final no intervalo ser pesquisado.

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

Valor de retorno

O número de elementos que satisfazem a condição especificada pelo predicado.

Comentários

Essa função do modelo é uma generalização do algoritmo contagem, substituindo o predicado “igual a um valor específico” 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: <algoritmo>

Namespace: std

Consulte também

Referência

count_if (Exemplos da STL)

Biblioteca de Modelos Padrão