Udostępnij za pośrednictwem


count_if

Zwraca liczbę elementów w zakresie, których wartości spełniają określony warunek.

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

Parametry

  • _First
    Wejściowy iteratora adresowania pozycja pierwszego elementu w zakresie mają być przeszukiwane.

  • _Last
    Wejściowy iteratora adresowania pozycji jeden obok ostatniego elementu w zakresie mają być przeszukiwane.

  • _Pred
    Zdefiniowana przez użytkownika funkcja predykatu obiektu, który definiuje warunek za spełniony, jeśli element jest do zliczania.Predykat przyjmuje jeden argument i zwraca true lub false.

Wartość zwracana

Liczba elementów, które spełniają warunek predykatu.

Uwagi

Ta funkcja szablonu jest generalizacji algorytmu liczby, zastępując predykat "równa określonej wartości" wszelkie predykat.

Przykład

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

Wymagania

Nagłówek: <algorytm>

Przestrzeń nazw: std

Zobacz też

Informacje

count_if (STL — Przykłady)

Standardowa biblioteka szablonów