Biblioteca de algoritmos C ++ - função any_of ()

Descrição

A função C ++ std::algorithm::any_of()Retorna verdadeiro se o predicado retornar verdadeiro para qualquer um dos elementos no intervalo do primeiro ao último . Se intervalo estiver vazio, também será retornado verdadeiro, caso contrário, retornará falso.

Declaração

A seguir está a declaração para o cabeçalho da função std :: algorithm :: any_of () std :: algorithm.

C ++ 11

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

Parâmetros

  • first - Insira iteradores nas posições iniciais em uma sequência.

  • last - Insira iteradores para as posições finais em uma sequência.

  • pred- Uma função de predicado unário que aceita um elemento e retorna um bool .

Valor de retorno

Retorna verdadeiro se o predicado retornar verdadeiro para qualquer um dos elementos no intervalo ou se o intervalo estiver vazio, caso contrário, retorna falso.

Exceções

Lança exceção se o predicado ou uma operação em um iterador lança exceção.

Observe que os parâmetros inválidos causam um comportamento indefinido.

Complexidade de tempo

Linear na distância entre o primeiro e o último .

Exemplo

O exemplo a seguir mostra o uso da função std :: algorithm :: any_of ().

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

using namespace std;

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

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

   result = any_of(v.begin(), v.end(), is_odd);

   if (result == true)
      cout << "Vector contains at least one odd number." << endl;

   v[4] = 10;

   result = any_of(v.begin(), v.end(), is_odd);

   if (result == false)
      cout << "Vector contains all even number." << endl;

   return 0;
}

Vamos compilar e executar o programa acima, isso produzirá o seguinte resultado -

Vector contains at least one odd number.
Vector contains all even number.