public member type
<unordered_set>

std::unordered_multiset::bucket_size

size_type bucket_size ( size_type n ) const;
返回桶的大小
返回桶 n 中的元素数量。

一个桶(bucket)是容器内部哈希表的一个槽,元素根据其哈希值被分配到其中。

桶中的元素数量会影响访问桶中特定元素所需的时间。容器会自动增加桶的数量,以保持负载因子(即平均桶大小)低于其最大负载因子

参数

n
桶编号。
这应该小于 bucket_count
成员类型size_type是一种无符号整型类型。

返回值

n 中的元素数量。

成员类型size_type是一种无符号整型类型。

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
// unordered_multiset::bucket_size
#include <iostream>
#include <string>
#include <unordered_set>

int main ()
{
  std::unordered_multiset<std::string> myums =
  {"human","klingon","klingon","vulcan","romulan","cardassian"};

  unsigned nbuckets = myums.bucket_count();

  std::cout << "myums has " << nbuckets << " buckets:\n";

  for (unsigned i=0; i<nbuckets; ++i) {
    std::cout << "bucket #" << i << " has " << myums.bucket_size(i) << " elements.\n";
  }

  return 0;
}

可能的输出(实际桶数取决于库实现)
myset has 7 buckets:
bucket #0 has 0 elements.
bucket #1 has 0 elements.
bucket #2 has 0 elements.
bucket #3 has 2 elements.
bucket #4 has 0 elements.
bucket #5 has 4 elements.
bucket #6 has 0 elements.


复杂度

线性于桶的大小。

迭代器有效性

没有变化。

另见