跳到主要内容

std::unordered_multiset count() 方法

// (1) Const version only
size_type count( const Key& key ) const;

// (2) Const version only
template< class K >
size_type count( const K& x ) const;
  • (1) 返回与指定参数 key 比较相等的元素的数量。
  • (2) 返回与指定参数 x 比较等价的元素的数量。此重载仅当 Hash::is_transparentKeyEqual::is_transparent 有效且都表示一个类型时才参与重载解析。这假定这样的 Hash 可以同时使用 KKey 类型调用,并且 KeyEqual 是透明的,这两者结合起来,允许在不构造 Key 实例的情况下调用此函数。

参数

  • key - 要计数的元素的键值
  • x - 可以与键透明比较的任何类型的值

返回值

  • (1) 具有键 key 的元素数量。
  • (2) 键与 x 等效的元素数量。

复杂度

平均情况,常数 - O(1)
最坏情况,与容器大小呈线性关系 - O(size())

异常

(无)

备注

功能测试宏:__cpp_lib_generic_unordered_lookup(针对重载 (2))。

示例

Main.cpp
#include <algorithm>
#include <iostream>
#include <unordered_set>

int main() {
std::unordered_multiset set{2, 7, 1, 8, 2, 8, 1, 8, 2, 8};

std::cout << "The set is:\n";
for (int e: set) { std::cout << e << ' '; }

const auto [min, max] = std::ranges::minmax(set);

std::cout << "\nNumbers [" << min << ".." << max << "] frequency:\n";

for (int i{min}; i <= max; ++i) {
std::cout << i << ':' << set.count(i) << "; ";
}
}
可能输出
The set is:
8 8 8 8 1 1 7 2 2 2
Numbers [1..8] frequency:
1:2; 2:3; 3:0; 4:0; 5:0; 6:0; 7:1; 8:4;
本文源自 此 CppReference 页面。可能为了改进或编辑偏好进行了修改。点击“编辑此页面”查看对本文档所做的所有更改。
悬停查看原始许可证。

std::unordered_multiset count() 方法

// (1) Const version only
size_type count( const Key& key ) const;

// (2) Const version only
template< class K >
size_type count( const K& x ) const;
  • (1) 返回与指定参数 key 比较相等的元素的数量。
  • (2) 返回与指定参数 x 比较等价的元素的数量。此重载仅当 Hash::is_transparentKeyEqual::is_transparent 有效且都表示一个类型时才参与重载解析。这假定这样的 Hash 可以同时使用 KKey 类型调用,并且 KeyEqual 是透明的,这两者结合起来,允许在不构造 Key 实例的情况下调用此函数。

参数

  • key - 要计数的元素的键值
  • x - 可以与键透明比较的任何类型的值

返回值

  • (1) 具有键 key 的元素数量。
  • (2) 键与 x 等效的元素数量。

复杂度

平均情况,常数 - O(1)
最坏情况,与容器大小呈线性关系 - O(size())

异常

(无)

备注

功能测试宏:__cpp_lib_generic_unordered_lookup(针对重载 (2))。

示例

Main.cpp
#include <algorithm>
#include <iostream>
#include <unordered_set>

int main() {
std::unordered_multiset set{2, 7, 1, 8, 2, 8, 1, 8, 2, 8};

std::cout << "The set is:\n";
for (int e: set) { std::cout << e << ' '; }

const auto [min, max] = std::ranges::minmax(set);

std::cout << "\nNumbers [" << min << ".." << max << "] frequency:\n";

for (int i{min}; i <= max; ++i) {
std::cout << i << ':' << set.count(i) << "; ";
}
}
可能输出
The set is:
8 8 8 8 1 1 7 2 2 2
Numbers [1..8] frequency:
1:2; 2:3; 3:0; 4:0; 5:0; 6:0; 7:1; 8:4;
本文源自 此 CppReference 页面。可能为了改进或编辑偏好进行了修改。点击“编辑此页面”查看对本文档所做的所有更改。
悬停查看原始许可证。