【C++ STL哈希容器】unordered_set 无序集合

news/2024/9/22 15:22:35/

【 1. 基本原理 】

  • <unordered_set> 头文件,std 命名空间。
  • 类模板定义
    • 以下 4 个参数中,只有第一个参数没有默认值,这意味着如果我们想创建一个 unordered_set 容器,至少需要手动传递 1 个参数。事实上,在 99% 的实际场景中最多只需要使用前 3 个参数最后一个参数保持默认值即可。
    • Key:确定容器存储元素的类型,如果读者将 unordered_set 看做是存储键和值相同的键值对的容器,则此参数则用于确定各个键值对的键和值的类型Hash = hash<Key>:指定 unordered_set 容器底层存储各个元素时,所使用的哈希函数。需要注意的是,默认哈希函数 hash 只适用于基本数据类型(包括 string 类型),而不适用于自定义的结构体或者类。
    • Hash = hash<Key>:指定 unordered_set 容器底层存储各个元素时,所使用的哈希函数。需要注意的是,默认哈希函数 hash 只适用于基本数据类型(包括 string 类型),而不适用于自定义的结构体或者类。
    • Pred = equal_to<Key>:unordered_set 容器内部不能存储相等的元素,而衡量 2 个元素是否相等的标准,取决于该参数指定的函数。 默认情况下,使用 STL 标准库中提供的 equal_to 规则,该规则仅支持可直接用 == 运算符做比较的数据类型。
    • 注意,如果 unordered_set 容器中存储的元素为自定义的数据类型,则默认的哈希函数 hash 以及比较函数 equal_to 将不再适用,只能自己设计适用该类型的哈希函数和比较函数,并显式传递给 Hash 参数和 Pred 参数。至于如何实现自定义,后续章节会做详细讲解。
template < class Key,            //容器中存储元素的类型class Hash = hash<Key>,    //确定元素存储位置所用的哈希函数class Pred = equal_to<Key>,   //判断各个元素是否相等所用的函数class Alloc = allocator<Key>   //指定分配器对象的类型> class unordered_set;

【 2. unordered_set 的定义 】

  • 创建 set 的所有方式完全适用于 unordereded_set 容器,详情看:【C++ STL有序关联容器】set 集合。

【 3. unordered 的成员方法 】

成员方法功能
begin()返回指向容器中第一个元素的正向迭代器。
end();返回指向容器中最后一个元素之后位置的正向迭代器。
cbegin()和 begin() 功能相同,只不过其返回的是 const 类型的正向迭代器。
cend()和 end() 功能相同,只不过其返回的是 const 类型的正向迭代器。
empty()若容器为空,则返回 true;否则 false。
size()返回当前容器中存有元素的个数。
max_size()返回容器所能容纳元素的最大个数,不同的操作系统,其返回值亦不相同。
find(key)查找以值为 key 的元素,如果找到,则返回一个指向该元素的正向迭代器;反之,则返回一个指向容器中最后一个元素之后位置的迭代器(如果 end() 方法返回的迭代器)。
count(key)在容器中查找值为 key 的元素的个数。
equal_range(key)返回一个 pair 对象,其包含 2 个迭代器,用于表明当前容器中值为 key 的元素所在的范围。
emplace()向容器中添加新元素,效率比 insert() 方法高。
emplace_hint()向容器中添加新元素,效率比 insert() 方法高。
insert()向容器中添加新元素。
erase()删除指定元素。
clear()清空容器,即删除容器中存储的所有元素。
swap()交换 2 个 unordered_set 容器存储的元素,前提是必须保证这 2 个容器的类型完全相等。
bucket_count()返回当前容器底层存储元素时,使用桶(一个线性链表代表一个桶)的数量。
max_bucket_count()返回当前系统中,unordered_set 容器底层最多可以使用多少桶。
bucket_size(n)返回第 n 个桶中存储元素的数量。
bucket(key)返回值为 key 的元素所在桶的编号。
load_factor()返回 unordered_set 容器中当前的负载因子。负载因子,指的是的当前容器中存储元素的数量(size())和使用桶数(bucket_count())的比值,即 load_factor() = size() / bucket_count()。
max_load_factor()返回或者设置当前 unordered_set 容器的负载因子。
rehash(n)将当前容器底层使用桶的数量设置为 n。
reserve()将存储桶的数量(也就是 bucket_count() 方法的返回值)设置为至少容纳 count 个元(不超过最大负载因子)所需的数量,并重新整理容器。
hash_function()返回当前容器使用的哈希函数对象。

实例–正向迭代器的定义方式 遍历 unordered_set

  • 查看已定义 uset 容器存储元素的个数,并通过正向迭代器输出各元素。
#include <iostream>
#include <string>
#include <unordered_set>
using namespace std;
int main()
{//创建一个空的unordered_set容器std::unordered_set<std::string> uset;//给 uset 容器添加数据uset.emplace("http://c.biancheng.net/java/");uset.emplace("http://c.biancheng.net/c/");uset.emplace("http://c.biancheng.net/python/");//查看当前 uset 容器存储元素的个数cout << "uset size = " << uset.size() << endl;//遍历输出 uset 容器存储的所有元素for (auto iter = uset.begin(); iter != uset.end(); ++iter) {cout << *iter << endl;}return 0;
}

在这里插入图片描述


http://www.ppmy.cn/news/1517420.html

相关文章

Golang反射:运行时类型检查与操作

反射的基本概念 反射是Go语言中的一个高级特性&#xff0c;它允许程序在运行时查询和使用类型信息。Go的反射基于reflect包&#xff0c;它定义了两个核心类型&#xff1a;Type和Value。 Type表示Go语言中每种类型的类型信息。Value表示值的接口&#xff0c;可以对值进行读取和…

mac m1 配置 frp

frp 是什么&#xff1f; frp 是一个专注于内网穿透的高性能的反向代理应用&#xff0c;支持 TCP、UDP、HTTP、HTTPS 等多种协议。可以将内网服务以安全、便捷的方式通过具有公网 IP 节点的中转暴露到公网。 官网 github 安装 配置公网服务器 下载服务端二进制文件&#xf…

清理linux的buff/cache缓存

通过free -m命令&#xff0c;查看内存占用率。 如果buff/cache 占用内存过高的话&#xff0c;执行以下命令 sync && echo 1 > /proc/sys/vm/drop_caches sync && echo 2 > /proc/sys/vm/drop_caches sync && echo 3 > /proc/sys/vm/drop_ca…

WEB开发---使用HTML CSS开发网页实时显示当前日期和时间

自己刚开始学习html css知识&#xff0c;临时做个网页&#xff0c;实时显示当前日期和时间功能。 代码如下&#xff1a; test.html <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport&q…

前端工程化:构建高效、可维护的前端项目

摘要 随着前端技术的快速发展&#xff0c;前端工程化成为了提高开发效率、保证项目质量的关键。本文将探讨前端工程化的概念、重要性以及实施策略&#xff0c;包括模块化开发、组件化架构、自动化构建和测试等&#xff0c;帮助开发者构建高效、可维护的前端项目。 1. 前端工程…

山东大数据职称考试复习

冒泡排序是稳定的。 双链表删除结点P的操作&#xff1a; 算法的思想就是&#xff1a;把P的前驱结点接上P的后继节点。然后P的后继节点的前驱节点指向P的前驱节点。这个时候P就被架空了。此时释放P. void DDeleteNode(DListNode *p){ //假设*P非最后的尾结点 …

[MRCTF2020]Unravel!!

使用zsteg查看图片有隐藏文件&#xff0c;没有头绪&#xff0c;先放弃 使用zsteg和010editor查看都发现一个png图片 把JM.png拷贝到kali&#xff0c;使用binwalk分离&#xff0c;得到一个aes.png 使用010editor查看wav&#xff0c;发现尾部有可疑的字符串&#xff0c;拷贝出来备…

AMEYA360 :“Radisol”,一款可改善智能手机Wi-Fi天线性能的村田电子新产品

株式会社村田制作所开发了村田首款(1)天线抗干扰器件‘Radisol’。Radisol是一款可配备到天线上来抑制无线性能下降的新产品&#xff0c;该产品已于2024年6月开始量产&#xff0c;并已用在Motorola Mobility LLC 2024年8月开始销售的智能手机“Edge系列”新机型。摩托罗拉通过采…