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.