namespace std {
template <class T, size_t N>
bool operator<(const array<T, N>& x, const array<T, N>& y); // C++11
template <class T, size_t N>
constexpr bool operator<(const array<T, N>& x, const array<T, N>& y); // C++20
}
概要
array
において、左辺が右辺より小さいかの判定を行う。
要件
型T
が<
比較可能であること。その<
が全順序関係を持っていること。
戻り値
lexicographical_compare(x.begin(), x.end(), y.begin(), y.end());
計算量
線形時間
例
#include <iostream>
#include <array>
int main ()
{
std::array<int, 3> x = {1, 2, 3};
std::array<int, 3> y = {4, 5, 6};
if (x < y) {
std::cout << "less" << std::endl;
}
else {
std::cout << "greater equal" << std::endl;
}
}
出力
less
バージョン
言語
- C++11
処理系
- Clang: ??
- GCC: 4.7.0
- ICC: ??
- Visual C++: 2008 (std::tr1), 2010, 2012