C++ Unordered_map 库 - cbegin() 函数
描述
C++ 函数 std::unordered_map::cbegin() 返回一个常量迭代器,指向它的一个桶中的第一个元素。
声明
以下是 std::unordered_map::cbegin() 函数形式 std::unordered_map 头的声明。
C++11
const_local_iterator cbegin(size_type n) const;
参数
n − 桶编号,必须小于 bucket_count。
返回值
返回常量迭代器。
时间复杂度
常数,即 O(1)
示例
以下示例显示了 std::unordered_map::cbegin() 函数的用法。
#include <iostream>
#include <unordered_map>
using namespace std;
int main(void) {
unordered_map<char, int> um = {
{'a', 1},
{'b', 2},
{'c', 3},
{'d', 4},
{'e', 5}
};
for (int i = 0; i < um.bucket_count(); ++i) {
cout << "Bucket " << i << " contains:" << endl;
for (auto it = um.cbegin(i); it != um.cend(i); ++it)
cout << it->first << " = " << it->second << endl;
}
return 0;
}
让我们编译并运行上面的程序,这将产生以下结果 −
Bucket 0 contains: c = 3 Bucket 1 contains: d = 4 Bucket 2 contains: e = 5 Bucket 3 contains: Bucket 4 contains: Bucket 5 contains: Bucket 6 contains: Bucket 7 contains: Bucket 8 contains: Bucket 9 contains: a = 1 Bucket 10 contains: b = 2