- algorithm[meta header]
- std[meta namespace]
- function template[meta id-type]
- cpp11[meta cpp]
namespace std {
template <class InputIterator, class Predicate>
bool any_of(InputIterator first,
InputIterator last,
Predicate pred); // (1) C++11
template <class InputIterator, class Predicate>
constexpr bool any_of(InputIterator first,
InputIterator last,
Predicate pred); // (1) C++20
template <class ExecutionPolicy, class ForwardIterator, class Predicate>
bool any_of(ExecutionPolicy&& exec,
ForwardIterator first,
ForwardIterator last,
Predicate pred); // (2) C++17
}
イテレータ範囲[first, last)
のいずれかの要素が条件を満たすかを判定する。
イテレータ範囲[first,last)
内のイテレータ i
について pred(*i)
が true
になるような要素があればtrue
を返し、そうでなければfalse
を返す。
イテレータ範囲[first,last)
が空の場合はfalse
を返す。
最大で last - first
回 pred
を実行する。
#include <algorithm>
#include <iostream>
#include <vector>
int main() {
std::vector<int> v = { 3, 1, 4 };
std::cout << std::boolalpha;
// 5 以上の要素が存在するかどうか
bool result1 = std::any_of(v.begin(), v.end(), [](int x) { return x >= 5; });
std::cout << result1 << std::endl;
// 1 の要素が存在するかどうか
bool result2 = std::any_of(v.begin(), v.end(), [](int x) { return x == 1; });
std::cout << result2 << std::endl;
}
- std::any_of[color ff0000]
false
true
template <class InputIterator, class Predicate>
bool any_of(InputIterator first, InputIterator last, Predicate pred) {
for ( ; first != last; ++first)
if (pred(*first)) return true;
return false;
}
- C++11
- Clang: 3.0 [mark verified]
- GCC: 4.4.7 [mark verified]
- Visual C++: 2010 [mark verified], 2012 [mark verified], 2013 [mark verified], 2015 [mark verified]