最終更新日時(UTC):
が更新

履歴 編集

function
<unordered_map>

std::unordered_multimap::bucket_size(C++11)

size_type bucket_size(size_type n) const;

概要

インデックス(添え字)で指定したバケット内に格納されている要素の数を取得する。

要件

パラメータ n[0, bucket_count()) の範囲であること。

戻り値

パラメータ nで指定した位置のバケット内に格納されている要素の数

計算量

O(bucket_size(n))

#include <iostream>
#include <unordered_map>
#include <algorithm>

int main()
{
  std::unordered_multimap<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.cbegin(b), um.cend(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

処理系

関連項目

名前 説明
bucket_count バケット数の取得
max_bucket_count 最大バケット数の取得
bucket キーで指定したバケットのインデックス(添え字)を取得
begin(size_type) インデックス(添え字)で指定したバケット内の先頭要素を指すイテレータを取得
end(size_type) インデックス(添え字)で指定したバケット内の最終要素の次を指すイテレータを取得
cbegin(size_type) インデックス(添え字)で指定したバケット内の先頭要素を指す読み取り専用イテレータを取得
cend(size_type) インデックス(添え字)で指定したバケット内の最終要素の次を指す読み取り専用イテレータを取得