- flat_set[meta header]
- std[meta namespace]
- flat_multiset[meta class]
- function[meta id-type]
- cpp23[meta cpp]
bool contains(const key_type& x) const; // (1) C++23
constexpr bool contains(const key_type& x) const; // (1) C++26
template <class K>
bool contains(const K& x) const; // (2) C++23
template <class K>
constexpr bool contains(const K& x) const; // (2) C++26指定されたキーxに一致する要素がコンテナに含まれているかを判定する。
- (1) : クラスのテンプレートパラメータ
key_type型のキーを受け取る - (2) :
key_typeと比較可能なK型のキーを受け取る
- (2) :
key_compare::is_transparentが妥当な式であること
以下と等価:
return find(x) != end();- find[link find.md]
- end()[link end.md]
対数時間
- (2) :
is_transparentは、標準ライブラリのstd::less、std::greaterといった関数オブジェクトの、voidに対する特殊化で定義される。それ以外のテンプレートパラメータでis_transparentが定義されないのは、互換性のためである。- これらのオーバーロードは、
flat_multiset<string>のようなコンテナに対し、検索操作で文字列リテラルを渡した際に、キー型の一時オブジェクトが生成されるコストを減らすためにある。
#include <flat_set>
#include <iostream>
int main()
{
std::flat_multiset<int> fs = {3, 1, 4, 1};
// キー3の要素が含まれているか
if (fs.contains(3)) {
std::cout << "contain" << std::endl;
}
else {
std::cout << "doesn't contain" << std::endl;
}
}- contains[color ff0000]
contain
- C++23
- Clang: ??
- GCC: ??
- Visual C++: ??