size_type bucket(const key_type& k) const;
概要
指定したキーと等価な要素が格納されている場合、そのバケットのインデックス(添え字)を取得する。
要件
当該コンテナは bucket_count() > 0
であること
戻り値
パラメータ k
と等価なキーの要素が格納されているバケットのインデックス(添え字)
戻り値は [0, bucket_count())
の範囲である。
計算量
定数。
備考
指定したキーと等価な要素が格納されていない場合、そのキーを挿入した際に rehash
が発生しなければ格納されるバケットのインデックス(添え字)が返る。
例
#include <iostream>
#include <unordered_map>
int main()
{
std::unordered_map<char, int> um = {
{'A', 1},
{'B', 2},
{'C', 3},
{'D', 4},
{'E', 5}
};
decltype(um)::size_type c = um.bucket_count();
std::cout << "bucket_count() = " << c << std::endl;
// 全てのキーに対するバケットのインデックスとそのバケットの要素数を取得
for (decltype(um)::const_reference x : um) {
decltype(um)::key_type k = x.first;
decltype(um)::size_type b = um.bucket(k);
decltype(um)::size_type s = um.bucket_size(b);
std::cout << "key = " << k << ", bucket = " << b << ", bucket_size = " << s << std::endl;
}
// 存在しないキーに対するバケットのインデックスとそのバケットの要素数を取得
decltype(um)::key_type k = 'H';
decltype(um)::size_type b = um.bucket(k);
decltype(um)::size_type s = um.bucket_size(b);
std::cout << "key = " << k << ", bucket = " << b << ", bucket_size = " << s << std::endl;
}
出力例
bucket_count() = 11
key = E, bucket = 3, bucket_size = 1
key = A, bucket = 10, bucket_size = 1
key = B, bucket = 0, bucket_size = 1
key = C, bucket = 1, bucket_size = 1
key = D, bucket = 2, bucket_size = 1
key = H, bucket = 6, bucket_size = 0
バージョン
言語
- C++11
処理系
- Clang: 3.1 ✅
- GCC: 4.7.2 ✅
- ICC: ?
- Visual C++: ?
関連項目
名前 | 説明 |
---|---|
max_bucket_count |
最大バケット数の取得 |