local_iterator begin(size_type n);
const_local_iterator begin(size_type n) const;
概要
インデックス(添え字)で指定したバケット内の先頭の要素を指すイテレータを取得する。
unordered_map
は非順序連想コンテナであるため「先頭」に特に意味はないが、begin(size_type)
で得られたイテレータを end(size_type)
まで operator++()
でイテレートすることで当該バケットの要素を漏れなくダブりなく走査することができる。
要件
パラメータ n
は [0, bucket_count())
の範囲でなければならない。
戻り値
インデックス(添え字) n
で指定したバケット内の先頭の要素を指すイテレータ
計算量
定数
例
#include <iostream>
#include <unordered_map>
#include <algorithm>
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)::size_type b = 0; b < c; ++b) {
decltype(um)::size_type s = um.bucket_size(b);
std::cout << "bucket = " << b << ", bucket_size = " << s << ", keys = { ";
std::for_each(um.begin(b), um.end(b), [](decltype(um)::const_reference x) {
std::cout << x.first << ", ";
});
std::cout << "}" << std::endl;
}
}
出力例
bucket_count() = 11
bucket = 0, bucket_size = 1, keys = { B, }
bucket = 1, bucket_size = 1, keys = { C, }
bucket = 2, bucket_size = 1, keys = { D, }
bucket = 3, bucket_size = 1, keys = { E, }
bucket = 4, bucket_size = 0, keys = { }
bucket = 5, bucket_size = 0, keys = { }
bucket = 6, bucket_size = 0, keys = { }
bucket = 7, bucket_size = 0, keys = { }
bucket = 8, bucket_size = 0, keys = { }
bucket = 9, bucket_size = 0, keys = { }
bucket = 10, bucket_size = 1, keys = { A, }
バージョン
言語
- C++11
処理系
- Clang: 3.1 ✅
- GCC: 4.7.0 ✅
- ICC: ?
- Visual C++: ?
関連項目
名前 | 説明 |
---|---|
begin |
先頭要素を指すイテレータの取得 |
end |
最終要素の次を指すイテレータの取得 |
cbegin |
先頭要素を指す読み取り専用イテレータの取得 |
cend |
最終要素の次を指す読み取り専用イテレータの取得 |
end(size_type) |
インデックス(添え字)で指定したバケット内の最終要素の次を指すイテレータを取得 |
cbegin(size_type) |
インデックス(添え字)で指定したバケット内の先頭要素を指す読み取り専用イテレータを取得 |
cend(size_type) |
インデックス(添え字)で指定したバケット内の最終要素の次を指す読み取り専用イテレータを取得 |