• Class / Function / Type

      std::
    • Header file

      <>
    • Other / All

    最終更新日時(UTC):
    が更新

    履歴 編集

    function template
    <algorithm>

    std::find_if

    namespace std {
      template <class InputIterator, class Predicate>
      InputIterator find_if(InputIterator first,
                            InputIterator last,
                            Predicate pred);               // (1) C++03
    
      template <class InputIterator, class Predicate>
      constexpr InputIterator find_if(InputIterator first,
                                      InputIterator last,
                                      Predicate pred);     // (1) C++20
    
      template <class ExecutionPolicy, class ForwardIterator, class Predicate>
      ForwardIterator find_if(ExecutionPolicy&& exec,
                              ForwardIterator first,
                              ForwardIterator last,
                              Predicate pred);             // (2) C++17
    }
    

    概要

    イテレータ範囲[first, last)の中から、指定された条件を満たす最初の要素を検索する。

    戻り値

    [first,last) 内のイテレータ i について、pred(*i) != false である最初のイテレータを返す。そのようなイテレータが見つからなかった場合は last を返す。

    計算量

    最大で last - first述語による比較を行う

    #include <algorithm>
    #include <iostream>
    #include <vector>
    
    int main() {
      std::vector<int> v = { 3, 1, 4 };
      // 3ではない最初の要素を検索する
      auto result = std::find_if(v.begin(), v.end(), [](int x) { return x != 3; });
      if (result == v.end()) {
        std::cout << "not found" << std::endl;
      } else {
        std::cout << "found: " << *result << std::endl;
      }
    }
    

    出力

    found: 1
    

    実装例

    template <class InputIterator, class Predicate>
    InputIterator find_if(InputIterator first, InputIterator last, Predicate pred) {
      for ( ; first != last; ++first)
        if (pred(*first)) return first;
      return last;
    }
    

    参照