STL无序关联容器—unorded_set+unorded_map

两个无序关联容器将底层的红黑树变成了哈希表。

一、核心定位(一句话)

  • unordered_set = 无序、更快、不排序set
  • unordered_map = 无序、更快、不排序map

它们底层是哈希表,所以:

  • 平均插入 / 查找 / 删除 O (1)(比 set/map 快很多)
  • 不保证顺序,遍历出来是乱的
  • 用法几乎和 set/map 完全一样

二、unordered_set 详细说明(基于 set)

1. 和 set 相同的地方(你已经会了)

  • 元素唯一,不能重复
  • insert() erase() find() count()
  • 迭代器遍历
  • 元素不能修改(必须删了重插)

2. 和 set 不同的地方(必须记住)

  1. 无序 插入 {3,1,2}set 输出:1 2 3unordered_set 输出:乱序(可能 2 1 3 或其他)

  2. 速度更快 set:O(log n)unordered_set:平均 O (1)

  3. 不支持 lower_bound /upper_bound因为没有顺序,无法范围查找。

  4. 头文件不同

    cpp 复制代码
    #include <unordered_set>

3. 常用代码(和 set 一模一样)

cpp 复制代码
unordered_set<int> us;

us.insert(5);    // 插入
us.erase(5);     // 删除
auto it = us.find(5); // 查找

if(it != us.end())
    cout << *it << endl;

4. 特别注意

  • 遍历顺序不固定
  • 千万不要依赖顺序
  • 性能比 set 好很多

三、unordered_map 详细说明(基于 map)

1. 和 map 相同的地方

  • 键唯一
  • 支持 []at()insert()erase()find()
  • 可以修改值 ,不能修改键
  • 用法几乎一样

2. 和 map 不同的地方

  1. 无序 map 按键排序unordered_map 不排序

  2. 速度更快 map:O(log n)unordered_map:平均 O (1)

  3. 不支持 lower_bound /upper_bound

  4. 头文件不同

    cpp 复制代码
    #include <unordered_map>

3. 代码示例(和 map 一样)

cpp 复制代码
unordered_map<int, string> um;

um[1] = "one";    // 插入/修改
um.insert({2, "two"});

auto it = um.find(1);
if(it != um.end())
    cout << it->second << endl;

四、最关键的 4 个区别(必背)

1. 顺序

  • set / map:有序
  • unordered:无序

2. 速度

  • set / map:O(log n)
  • unordered:平均 O (1) 更快

3. 底层结构

  • set /map:红黑树
  • unordered:哈希表

4. 范围查找

  • set /map:支持 lower_bound
  • unordered:不支持
相关推荐
clint4564 天前
C++进阶(1)——前景提要
c++
夜悊4 天前
C++代码示例:进制数简单生成工具
c++
郝学胜_神的一滴4 天前
CMake 021: IF 条件判据详诠
c++·cmake
_wyt0014 天前
洛谷 B3930 [GESP202312 五级] 烹饪问题 题解
c++·gesp
LDR0065 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术5 天前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript
码云数智-园园5 天前
C++20 Modules 模块详解
java·开发语言·spring
swordbob5 天前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
源分享5 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
Luminous.5 天前
C语言--day30
c语言·开发语言