STL——map/unordered_map

pair对组创建:pair<type,type> p(value1,value2);

pair<type,type> p = make_pair(value1,value2);

map

map中所有元素都是pair,第一个元素为key,第二个为value

所有元素会根据键值自动排序

也是基于红黑树实现,支持高效插入、查找和删除操作,复杂度都是O(logn)

可以根据key值快速找到value值

map和multimap区别

  • map不允许容器中有重复key值元素

  • multimap允许容器中有重复key值元素

map构造赋值

  • map<T1,T2> map; //map默认构造函数

  • map(const map &mp); //拷贝构造函数

  • map& operator=(const map &mp); //重载等号运算符

map大小和交换

统计map容器大小以及交换map容器

  • size(); //返回容器中元素的数目

  • empty(); //判断容器是否为空

  • swap(st); //交换两个集合容器

插入删除

  • insert(elem); //在容器中插入元素。

  • clear(); //清除所有元素

  • erase(pos); //删除pos迭代器所指的元素,返回下一个元素的迭代器。

  • erase(beg, end); //删除区间[beg,end)的所有元素 ,返回下一个元素的迭代器。

  • erase(key); //删除容器中值为key的元素。

查找统计

  • find(key); //查找key是否存在,若存在,返回该键的元素的迭代器;若是multimap,则是返回第一个满足的迭代器,若不存在,返回end();

  • count(key); //统计key的元素个数

排序

map默认按照key值进行从小到达排序,使用仿函数可以进行自定义排序,规则与set类似

自定义类型则必须设置排序方式

map<Person, int, MyCompare> m;

unordered_map

基于哈希表实现 ,故在插入、删除和查找操作能在常数复杂度**O(1)**实现

也保持了键的唯一性,但不会根据键值自动排序

常用接口与map一致,同时遍历顺序下也是不一致的

适合于需要用于快速查找、删除和插入唯一元素,但不关心元素顺序的场景

性能注意事项:

  • 当unordered_map元素数量增长超过哈希容量的负载因子时,哈希表将重新进行哈希操作,这可能会比较耗时,因此通常可以预先确定将要存储的元素数量进行reverse()方法来预分配足够的空间以提高效率
相关推荐
大白话_NOI3 分钟前
【洛谷 P1303】A*B Problem + 详细分析
c++
小欣加油10 分钟前
leetcode2161 根据给定数字划分数组
数据结构·c++·算法·leetcode·职场和发展
程序员晨曦10 分钟前
Java 并发修仙传:ThreadLocal 从“闭关修炼”到“走火入魔”的救赎之路
java·开发语言
李可以量化17 分钟前
量化之MiniQMT 实战:一键读取通达信自选股并实时监控涨跌幅(附完整可运行代码)
开发语言·python·量化·qmt·ptrade
嘶哈哈哈19 分钟前
嘉立创 EDA 入门实操笔记:从原理图到 PCB 布线、差分对、覆铜与 DRC 检查
开发语言·笔记·php
吃着火锅x唱着歌24 分钟前
深度探索C++对象模型 学习笔记 第五章 构造、解构、拷贝语意学(2)
c++·笔记·学习
玖釉-26 分钟前
Vulkan 离屏渲染详解:从 Framebuffer 到后处理、阴影贴图与 Render Texture
c++·windows·计算机视觉·图形渲染
wgc2k28 分钟前
Nest.js 基础-8-Hello,NestJS
开发语言·javascript·ecmascript
子午34 分钟前
基于DeepSeek的酒店客房管理系统~Python+DeepSeek智能问答+Vue3+Web网站系统
开发语言·前端·python
ghie909035 分钟前
基于 MATLAB 的序贯蒙特卡洛概率假设密度多目标跟踪实现
开发语言·matlab·目标跟踪