std::unordered_map<Key,T,Hash,KeyEqual,Allocator>::contains
来自cppreference.com
< cpp | container | unordered map
bool contains( const Key& key ) const; |
(1) | (C++20 起) |
template< class K > bool contains( const K& x ) const; |
(2) | (C++20 起) |
1) 检查容器中是否有元素的键等价于 key。
2) 检查是否有元素的键比较等价于值 x。此重载只有在Hash::is_transparent 与 KeyEqual::is_transparent 均合法并指代类型时才会参与重载决议。这假设使得
Hash
能用 K
和 Key
类型调用,并且 KeyEqual
是透明的,进而允许调用此函数时不需要构造 Key
的实例。参数
key | - | 要搜索的元素键值 |
x | - | 任何能与键进行透明比较的类型的值 |
返回值
若有这种元素则为 true,否则为 false。
复杂度
平均为常数,最坏情况与容器大小成线性。
示例
运行此代码
#include <iostream> #include <unordered_map> int main() { std::unordered_map<int, char> example{{1, 'a'}, {2, 'b'}}; for (int x : {2, 5}) if (example.contains(x)) std::cout << x << ": 找到\n"; else std::cout << x << ": 未找到\n"; }
输出:
2: 找到 5: 未找到
参阅
寻找带有特定键的元素 (公开成员函数) | |
返回匹配特定键的元素数量 (公开成员函数) | |
返回匹配特定键的元素范围 (公开成员函数) |