从零开始手写STL库:unordered_set

devtools/2024/9/23 0:39:55/

从零开始手写STL库–unordered_set的实现

Gihub链接:miniSTL


文章目录

  • 从零开始手写STL库–unordered_set的实现
  • 一、unordered_set是什么
  • 二、unordered_set要包含什么函数
  • 总结


一、unordered_set是什么

在STL中,std::unordered_set 是一个无序关联容器,其内部基于哈希表实现。

哈希表在本流程中已经实现过了,使用key来储存,储存内容为value,而unordered_set实际上就是一层封装

但是注意要把value屏蔽掉,因为set是一维的

二、unordered_set要包含什么函数

就是非常简单的封装,包含插入删除查找函数即可

template <typename Key> class Unordered_set 
{
public:Unordered_set() : hashtable(){};~Unordered_set(){}bool empty() const noexcept { return hashtable.size() == 0; }size_t size() const noexcept { return hashtable.size(); }void clear() noexcept { hashtable.clear(); }void insert(Key key) { hashtable.insertKey(key); }void erase(Key key) { hashtable.erase(key); }bool find(const Key &key) { return hashtable.find(key) != nullptr; }private:myHashTable<Key, Key> hashtable;
};

总结

1、注意UnSet和Set的区别,在于底层实现不同,前者是哈希表,后者是红黑树
2、UnSet的搜索效率是O(1)面试真题,被问过了
其他就没什么要注意的了,了解哈希表就能说出来unordered_set的特性了


http://www.ppmy.cn/devtools/97827.html

相关文章

【数据同步】SeaTunnel初体验,5000字深入浅出带你用上Oracle-CDC

Apache SeaTunnel 是啥&#xff1f;下一代高性能、分布式、海量数据集成框架。支持上百个数据源、传输速度快、准确率高&#xff0c;丰富易扩展的连接器和插件化的连接器设计&#xff0c;能够更轻松的运行复杂的集成。是一个分布式、高性能的数据集成平台&#xff0c;用于数据迁…

软件工程造价师习题练习 16

1.功能点分析方法是一种从&#xff08; &#xff09;视角来度量软件向用户提供的功能规模的方法 A. 需求分析 B. 用户 C. 开发 D. 测试 功能点分析方法是一种软件规模估算方法&#xff0c;其主要目的是从用户的角度来测量软件提供的功能规模。这意味着它关注的是用户所需的…

延时仅33us,Linux-RT实时性能测试分享—基于瑞芯微RK3562J国产平台

本文主要介绍瑞芯微RK3562J的实时性测试&#xff0c;开发环境如下&#xff1a; U-Boot&#xff1a;U-Boot-2017.09 Kernel&#xff1a;Linux-RT-5.10.198 LinuxSDK&#xff1a; LinuxSDK-[版本号] &#xff08;基于RK3562_LINUX_SDK_RELEASE_V1.1.0_20231220&#xff09; …

ee trade:黄金投资与股票投资的区别

黄金和股票&#xff0c; 是金融市场中两种常见的投资工具&#xff0c; 它们拥有截然不同的特点和风险&#xff0c; 了解它们的差异&#xff0c; 可以帮助投资者制定更合理的投资策略。 一、 投资性质&#xff1a; 避险与成长&#xff0c; 两种投资方向 黄金&#xff1a; 被视…

Java数组怎么转List,Stream的基本方法使用教程

Stream流 Java 的 Stream 流操作是一种简洁而强大的处理集合数据的方式,允许对数据进行高效的操作,如过滤、映射、排序和聚合。Stream API 于 Java 8 引入,极大地简化了对集合(如 List、Set)等数据的处理。 一、创建 Stream 从集合创建: List<String> list = Ar…

Python 连接数据库实现 CRUD(MySQL)

本指南将演示如何使用 Python 连接 MySQL 数据库&#xff0c;并实现 CRUD&#xff08;创建、读取、更新、删除&#xff09;操作。 1. 准备工作 1.1 安装 MySQL 连接器 使用 pip 安装 mysql-connector-python 库: pip install mysql-connector-python 1.2 准备数据库和表 确…

如何使用 Jupyter Notebook

Jupyter Notebook 是数据科学、机器学习、学术研究和开发领域中常用的交互式工具。它允许你在浏览器中创建和共享包含代码、文本、可视化和公式的文档。下面我们将从安装、启动、基本操作和高级用法等方面&#xff0c;详细介绍如何使用 Jupyter Notebook。 我自己用时的效果图…

深入单例模式

1. 饿汉模式 饿坏了&#xff0c;上来就先实例化一个对象&#xff0c;好处是代码简单&#xff0c;坏处是这个对象后面如果一直用不到&#xff0c;就是个浪费。 public class A{ private static A a new A(); private A(){} public static A getInstance(){ return a; } } 2. 懒…