count_if

[機能]

  指定した範囲で,単項関数オブジェクトが真となる要素の数を返します.

[形式]
#include <algorithm>

template <class InputIterator, class Predicate>
    typename iterator_traits<InputIterator>::difference_type count_if
    (InputIterator first, InputIterator last, Predicate pred);		

[使用例]

  1. count と count_if の使用方法です.以下に示すプログラム例において,いくつかのコメント部分は,その上または下に記述された方法とほぼ同等なものであることを示しています(複数行の対応関係である場合もある).
    #include <stdio.h>
    #include <vector>
    #include <algorithm>
    
    using namespace std;
    					// 奇数の判定
    //bool is_odd(int x) {
    //	return x % 2 > 0;
    //}
    
    class is_odd : public unary_function<int, bool>
    {
    	public:
    		result_type operator() (argument_type k)
    		{
    			return (result_type)(k % 2);
    		}
    };
    
    int main()
    {
    					// 初期設定
    	vector<int> v {4, 1, 4, 3, 4};
    	printf("vector v :");
    	for (auto x : v)
    		printf("  %d", x);
    	printf("\n");
    					// 4 である要素の数
    	int n = count(v.begin(), v.end(), 4);
    	printf("4 である要素数: %d\n", n);
    					// 奇数である要素の数
    	n = count_if(v.begin(), v.end(), is_odd());   // 単項関数オブジェクト
    //	n = count_if(v.begin(), v.end(), is_odd);   // 関数
    //	n = count_if(v.begin(), v.end(), [](int x){ return x%2 > 0; });   // ラムダ式
    	printf("奇数の要素数: %d\n", n);
    
    	return 0;
    }
    			
    (出力)
    vector v :  4  1  4  3  4
    4 である要素数: 3
    奇数の要素数: 2			
[参照]

count

菅沼ホーム 本文目次 演習問題解答例 付録目次 索引