P5【知识点】【数据结构】【哈希表unordered_set】C++版

哈希集合(如 C++ 中的 std::unordered_set)具有以下特点:

  1. 元素唯一性:哈希集合中的元素是唯一的,即集合中不会出现重复的元素。如果尝试插入一个已存在的元素,该操作将不会有任何效果。

  2. 基于哈希表:哈希集合内部使用哈希表来存储元素。哈希表通过哈希函数将元素映射到数组的某个位置(桶),从而可以快速地进行插入、删除和查找操作。

  3. 无序性:哈希集合中的元素是无序的,即元素的插入顺序与遍历顺序可能不同。

元操作:

1.访问(Access) 不支持

2.搜索(Search)

  • 有地址冲突 O(K)
  • 无地址冲突 O(1)

3.插入(Insert)

  • 有地址冲突 O(K)
  • 无地址冲突 O(1)

4.删除(delete)

  • 有地址冲突 O(K)
  • 无地址冲突 O(1)

具体操作:

1. 创建集合

cpp 复制代码
std::unordered_set<std::string> my_set; 

2.添加元素

cpp 复制代码
 // 插入元素  
    my_set.insert("apple");  
    my_set.insert("banana");  
    my_set.insert("cherry");

3.删除元素

cpp 复制代码
// 删除元素  
    my_set.erase("banana");  

4.查询元素

cpp 复制代码
if (my_set.find("apple") != my_set.end()) {  
}

5.获取长度

cpp 复制代码
std::size_t size = my_set.size(); 

力扣练习:

【217】存在重复元素

【705】设计哈希集合

相关推荐
奔跑吧 android3 小时前
【linux kernel 常用数据结构和设计模式】【数据结构 2】【通过一个案例属性list、hlist、rbtree、xarray数据结构使用】
linux·数据结构·list·kernel·rbtree·hlist·xarray
汉克老师3 小时前
第十四届蓝桥杯青少组C++选拔赛[2023.2.12]第二部分编程题(5、机甲战士)
c++·算法·蓝桥杯·01背包·蓝桥杯c++·c++蓝桥杯
Mr_Xuhhh4 小时前
项目需求分析(2)
c++·算法·leetcode·log4j
默默无名的大学生5 小时前
数据结构—顺序表
数据结构·windows
PAK向日葵5 小时前
【C/C++】面试官:手写一个memmove,要求性能尽可能高
c语言·c++·面试
Jared_devin6 小时前
二叉树算法题—— [蓝桥杯 2019 省 AB] 完全二叉树的权值
数据结构·c++·算法·职场和发展·蓝桥杯
搞全栈小苏6 小时前
基于Qt QML和C++的MQTT测试客户端(CMakeLists实现)
xml·c++·qt
啊?啊?6 小时前
18 从对象内存到函数调用:C++ 虚函数表原理(继承覆盖 / 动态绑定)+ 多态实战
开发语言·c++·多态原理
bkspiderx6 小时前
C++标准库:文件流类
开发语言·c++
一拳一个呆瓜6 小时前
【MFC】对话框属性:X Pos(X位置),Y Pos(Y位置)
c++·mfc