Przestrzenie nazw
Warianty

operator==,!=,<,<=,>,>=(std::pair)

Z cppreference.com
<tbody> </tbody> <tbody class="t-dcl-rev "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev "> </tbody><tbody> </tbody>
Zdefiniowane w nagłówku <utility>
template< class T1, class T2 > bool operator==( const pair<T1,T2>& lhs, const pair<T1,T2>& rhs );
(1)
template< class T1, class T2 > bool operator!=( const pair<T1,T2>& lhs, const pair<T1,T2>& rhs );
(2)
template< class T1, class T2 > bool operator<( const pair<T1,T2>& lhs, const pair<T1,T2>& rhs );
(3)
template< class T1, class T2 > bool operator<=( const pair<T1,T2>& lhs, const pair<T1,T2>& rhs );
(4)
template< class T1, class T2 > bool operator>( const pair<T1,T2>& lhs, const pair<T1,T2>& rhs );
(5)
template< class T1, class T2 > bool operator>=( const pair<T1,T2>& lhs, const pair<T1,T2>& rhs );
(6)
1-2) Testuje, czy oba elementy lhs i rhs są do siebie równe, to jest porównuje lhs.first z rhs.first i lhs.second z rhs.second
3-6) Porównuje lhs i rhs leksykograficznie, to jest porównuje pierwsze elementy, i tylko jeśli są równe, porównuje drugie elementy.

Parametry

lhs, rhs - pary do porównania

Zwracana wartości

1) true jeśli zarówno lhs.first == rhs.first i lhs.second == rhs.second, w przeciwnym razie false

2) true jeśli lhs.first != rhs.first lub lhs.second != rhs.second, w przeciwnym razie false

3) Jeśli lhs.first<rhs.first, zwraca true. W przeciwnym razie, jeśli rhs.first<lhs.first, zwraca false. W przeciwnym razie, jeśli lhs.second<rhs.second, zwraca true. W przeciwnym razie, zwraca false.

4) !(rhs < lhs)

5) rhs < lhs

6) !(lhs < rhs)

Przykład

Ponieważ operator< jest zdefiniowany dla par, kontenery par mogą być sortowane.

#include <iostream>
#include <utility>
#include <vector>
#include <algorithm>
#include <string>

int main()
{
    std::vector<std::pair<int, std::string>> v = { {2, "baz"},
                                                   {2, "bar"},
                                                   {1, "foo"} };
    std::sort(v.begin(), v.end());

    for(auto p: v) {
        std::cout << "(" << p.first << "," << p.second << ")\n";
    }
}

Wynik:

(1,foo)
(2,bar)
(2,baz)
Morty Proxy This is a proxified and sanitized view of the page, visit original site.