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.