跳到主要内容

std::unordered_set 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 相等(比较)的元素数量,由于此容器不允许重复,所以其值为 10
  • (2) 返回键与指定参数 x 等效(比较)的元素数量。此重载仅在 Hash::is_transparentKeyEqual::is_transparent 有效且各自表示一个类型时才参与重载解析。这假设此 Hash 可以与 KKey 类型一起调用,并且 KeyEqual 是透明的,这共同允许在不构造 Key 实例的情况下调用此函数。

参数

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

返回值

  • (1) 键为 key 的元素数量,即 10
  • (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_set set{2, 7, 1, 8, 2, 8, 1, 8, 2, 8};

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

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

std::cout << "\nNumbers from " << min << " to " << max << " that are in the set: ";
for (int i{min}; i <= max; ++i) {
if (set.count(i) == 1) {
std::cout << i << ' ';
}
}
}
可能输出
The set is: 8 1 7 2
Numbers from 1 to 8 that are in the set: 1 2 7 8
本文档源自 此 CppReference 页面。它可能为了改进或编辑者偏好而进行了修改。点击“编辑此页面”查看本文档所做的所有更改。
悬停查看原始许可证。

std::unordered_set 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 相等(比较)的元素数量,由于此容器不允许重复,所以其值为 10
  • (2) 返回键与指定参数 x 等效(比较)的元素数量。此重载仅在 Hash::is_transparentKeyEqual::is_transparent 有效且各自表示一个类型时才参与重载解析。这假设此 Hash 可以与 KKey 类型一起调用,并且 KeyEqual 是透明的,这共同允许在不构造 Key 实例的情况下调用此函数。

参数

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

返回值

  • (1) 键为 key 的元素数量,即 10
  • (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_set set{2, 7, 1, 8, 2, 8, 1, 8, 2, 8};

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

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

std::cout << "\nNumbers from " << min << " to " << max << " that are in the set: ";
for (int i{min}; i <= max; ++i) {
if (set.count(i) == 1) {
std::cout << i << ' ';
}
}
}
可能输出
The set is: 8 1 7 2
Numbers from 1 to 8 that are in the set: 1 2 7 8
本文档源自 此 CppReference 页面。它可能为了改进或编辑者偏好而进行了修改。点击“编辑此页面”查看本文档所做的所有更改。
悬停查看原始许可证。