C++ 算法库 - all_of() 函数


描述

C++ 函数std::algorithm::all_of()如果谓词对firstlast范围内的所有元素返回true,则返回true 。如果 range 为空,则返回 true,否则返回 false。

宣言

以下是 std::algorithm::all_of() 函数形式 std::algorithm 标头的声明。

C++11

template <class InputIterator, class UnaryPredicate>
bool all_of (InputIterator first, InputIterator last, UnaryPredicate pred);

参数

  • first - 将迭代器输入到序列中的初始位置。

  • 最后- 将迭代器输入到序列中的最终位置。

  • pred - 接受元素并返回bool 的一元谓词函数。

返回值

如果谓词对范围内的所有元素返回 true,则返回 true,或者如果范围为空,则返回 true,否则返回 false。

例外情况

如果谓词或迭代器上的操作抛出异常,则抛出异常。

请注意,无效参数会导致未定义的行为。

时间复杂度

与firstlast之间的距离呈线性关系。

例子

以下示例显示了 std::algorithm::all_of() 函数的用法。

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

bool is_even(int n) {
   return (n % 2 == 0);
}

int main(void) {
   vector<int> v = {2, 4, 6, 8, 10};
   bool result;

   result = all_of(v.begin(), v.end(), is_even);

   if (result == true)
      cout << "Vector contains all even numbers." << endl;

   v[0] = 1;

   result = all_of(v.begin(), v.end(), is_even);

   if (result == false)
      cout << "Vector doesn't contain all even numbers." << endl;

   return 0;
}

让我们编译并运行上面的程序,这将产生以下结果 -

Vector contains all even numbers.
Vector doesn't contain all even numbers.
算法.htm