Libreria di algoritmi C ++ - funzione any_of ()

Descrizione

La funzione C ++ std::algorithm::any_of()Restituisce vero se predicati Restituisce vero per qualsiasi degli elementi della gamma di prima a durare . Se range è vuoto, viene restituito anche true, altrimenti restituisce false.

Dichiarazione

Di seguito è riportata la dichiarazione per std :: algoritmo :: any_of () modulo std :: intestazione algoritmo.

C ++ 11

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

Parametri

  • first - Input iteratori nelle posizioni iniziali in una sequenza.

  • last - Input iteratori nelle posizioni finali in una sequenza.

  • pred- Una funzione predicato unario che accetta un elemento e restituisce un valore bool .

Valore di ritorno

Restituisce true se il predicato restituisce true per uno qualsiasi degli elementi nell'intervallo o se l'intervallo è vuoto, altrimenti restituisce false.

Eccezioni

Genera un'eccezione se il predicato o un'operazione su un iteratore genera un'eccezione.

Tieni presente che i parametri non validi causano un comportamento indefinito.

Complessità temporale

Lineare nella distanza tra il primo e l' ultimo .

Esempio

L'esempio seguente mostra l'utilizzo della funzione std :: algoritmo :: 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;
}

Compiliamo ed eseguiamo il programma sopra, questo produrrà il seguente risultato:

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