std::unordered_multiset count() 方法
- 自 C++20 起
- 自 C++11 起
// (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) Const version only
size_type count( const Key& key ) const;
- (1) 返回与指定参数
key
比较相等的元素的数量。 - (2) 返回与指定参数
x
比较等价的元素的数量。此重载仅当Hash::is_transparent
和KeyEqual::is_transparent
有效且都表示一个类型时才参与重载解析。这假定这样的Hash
可以同时使用K
和Key
类型调用,并且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;