deque::operator== a deque::operator<
Znázorňuje použití deque::operator == a deque::operator < funkce standardní šablonu knihovny (STL) v jazyce C++.
template<class T, class A>
bool operator==(
const deque <T, A>& Left,
const deque <T, A>& Right
);
template<class T, class A>
bool operator<(
const deque <T, A>& Left,
const deque <T, A>& Right
);
Poznámky
[!POZNÁMKA]
Názvy tříd/parametr v prototyp verze v záhlaví souboru neodpovídají.Některé byly upraveny, aby se zlepšila čitelnost.
První funkce přetížení šablony operator== porovnat dva objekty šablony třídy deque.Funkce vrátí vlevo.size == Right. velikosti & & equal(Left.začít, Left.end, Right.begin).Rovnost musí být počet prvků v obou objektů deque.Druhá funkce přetížení šablony operátor < porovnat dva objekty šablony třídy deque.Funkce vrátí: lexicographical_compare(vlevo.začít, Left.end, Right.begin, Right.end).Protože lexicographical_compare je použita, počet prvků nezáleží při použití operátor <.Ukázkový kód přidání řádku kódu při vytváření b objektu, jako například b.push_front('D');, will make b greater than a.
Příklad
// deque_operators.cpp
// compile with: /EHsc
//
// Functions:
// ==
// <
#include <iostream>
#include <deque>
using namespace std;
typedef deque<char > CHARDEQUE;
void print_contents (CHARDEQUE deque, char*);
int main()
{
//create a with 3 A's
CHARDEQUE a(3,'A');
a.push_front('C');
//create b with 4 B's.
CHARDEQUE b(6,'B');
//print out the contents
print_contents (a,"a");
print_contents (b,"b");
//compare a and b
if (a==b)
cout <<"a is equal to b"<<endl;
else if(a<b)
cout <<"a is less than b"<<endl;
else
cout <<"a is greater than b" <<endl;
//assign the contents of b to a
a.assign(b.begin(),b.end());
print_contents (a,"a");
print_contents (b,"b");
//compare a and b again
if (a==b)
cout <<"a is equal to b"<<endl;
else if(a<b)
cout <<"a is less than b"<<endl;
else
cout <<"a is greater than b" <<endl;
}
//function to print the contents of deque
void print_contents (CHARDEQUE deque, char *name)
{
CHARDEQUE::iterator pdeque;
cout <<"The contents of "<< name <<" : ";
for(pdeque = deque.begin();
pdeque != deque.end();
pdeque++)
{
cout << *pdeque <<" " ;
}
cout<<endl;
}
Výsledek
The contents of a : C A A A
The contents of b : B B B B B B
a is greater than b
The contents of a : B B B B B B
The contents of b : B B B B B B
a is equal to b
Požadavky
Záhlaví: <deque>