C++中set和map的使用

1.关联式容器

序列式容器里存储的是元素本身,如vector、list、deque

关联式容器即,容器中存储<key,value>的键值对 ,树型结 构的关联式容器主要有四种:map、set、multimap、multiset 。他们都使用**平衡搜索树(即红黑树)**作为其底层结果,容器中的元素是一个有序的序列。

2.键值对

**键值对即用来表示具有一一对应关系的一种结构,该结构中一般只包含两个成员变量key和value,key代表键值,value表示与key对应的信息。**类似如下结构

cpp 复制代码
template<class T1,class T2>
class pair{
public:
    T1 first;
    T2 second;

pair(): first(T1()), second(T2())
{}
 
pair(const T1& a, const T2& b): first(a), second(b)
{}
};

3.set的使用

在set中,元素的value也标识它(value就是key,类型为T),并且每个value必须是唯一的。 set中的元素不能在容器中修改(元素总是const),但是可以从容器中插入或删除它们。

set包含于<set>中

3.1set的定义

cpp 复制代码
set<int> s_int;

3.2set的主要操作

set不允许相同值插入若插入成功会返回pair<指向其的迭代器,成功>,插入失败会返回pair<指向原有值的迭代器,失败>

erase常用(2)直接删除指定值

find可以寻找值,返回其迭代器

4.map的使用

在map中,键值key通常用于排序和惟一地标识元素,而值value中存储与此键值key关联的内容。键值key和值value的类型可能不同,并且在map的内部,key与value绑定在一起,为其取别名称为pair

map包含于<map>

4.1map的定义

4.2map的主要操作

map的主要操作与set类似,insert不允许相同值插入

4.3map的operator[]

operator[] 能够访问包含对应key的pair的value

此操作也可解释为如下,即插入pair<key,value>取其返回的迭代器解引用的second,即返回对应key的value

使用实例如下

cpp 复制代码
map<string,string> m;

m["left"] = "左";//map中不存在此key,表示插入+修改
m["left"] = "左、剩余";//map中已存在此key,表示修改
m["insert"];//表示修改
cout << m["insert"];//表示查找

5.multimap、multiset

multimap、multiset即允许多个相同key存在的map和set。

set与multiset操作区别有:

1.find查找时,多个x在树中返回第一个x(中序的第一个)

2.插入时,允许相同值插入

3.erase会删除所有x

map与multimap操作区别有:

1.find查找时,多个x在树中返回第一个x(中序的第一个)

2.插入时,允许相同值插入

3.erase会删除所有x

4.无operator[]

相关推荐
没有bug.的程序员20 小时前
Spring Cloud Alibaba 生态总览
java·开发语言·spring boot·spring cloud·alibaba
快乐非自愿21 小时前
Java垃圾收集器全解:从Serial到G1的进化之旅
java·开发语言·python
树在风中摇曳21 小时前
Java 静态成员与继承封装实战:从报错到彻底吃透核心特性
java·开发语言
芳草萋萋鹦鹉洲哦1 天前
【Windows】tauri+rust运行打包工具链安装
开发语言·windows·rust
权泽谦1 天前
R Shiny 交互式网页实战:从零到上线可视化应用
开发语言·信息可视化·r语言
hweiyu001 天前
Go Fiber 简介
开发语言·后端·golang
Molesidy1 天前
【VSCode】【Clangd】Win下的基于LLVM/Clangd+Clangd插件+MINGW+CMake的VSCode配置C/C++开发环境的详细教程
c++·ide·vscode·clangd·llvm
ᐇ9591 天前
Java LinkedList集合全面解析:双向链表的艺术与实战
java·开发语言·链表
码银1 天前
【数据结构】顺序表
java·开发语言·数据结构
Mr_WangAndy1 天前
C++_chapter13_C++并发与多线程_多线程概念,死锁,unique_lock(),lock_guard()使用
c++·lock·死锁·并发与多线程·unlock·lock_guard·unique_lock