【C++】map、set基本用法

简介: 本文介绍了C++ STL中的`map`和`set`两种关联容器。`map`用于存储键值对,每个键唯一;而`set`存储唯一元素,不包含值。两者均基于红黑树实现,支持高效的查找、插入和删除操作。文中详细列举了它们的构造方法、迭代器、容量检查、元素修改等常用接口,并简要对比了`map`与`set`的主要差异。此外,还介绍了允许重复元素的`multiset`和`multimap`。

前言:

C++的STL已经学习很大一部分了,接下来介绍的是map set是c++的是两种关联容器。

简单介绍

map set

  • 两者都使用红黑树作为底层数据结构来存储元素。
  • map是一种键值对容器,其中每个键都是唯一的,并且与一个值相关联。
  • set则是一个元素集合,其中的每个元素也是唯一的,但它不存储与元素相关联的值。

set(K模型)

set使用介绍

set是标准模板库(STL)中的一种关联容器,它存储的元素是唯一的,并且按照特定的顺序(默认是升序)自动排序。

set的构造

函数声明 功能介绍
set (const Compare& comp = Compare(), const Allocator& = Allocator() ); 构造空的set
set (InputIterator first, InputIterator last, const Compare& comp = Compare(), const Allocator& = Allocator() ); 用[first, last)区 间中的元素构造
set set ( const set& x); set的拷贝构造

set的迭代器

函数声明 功能介绍
iterator begin() 返回set中起始位置元素的迭代器
iterator end() 返回set中最后一个元素后面的迭代器
const_iterator cbegin() const 返回set中起始位置元素的const迭代器
const_iterator cend() const 返回set中最后一个元素后面的const迭代器
reverse_iterator rbegin() 返回set第一个元素的反向迭代器,即end
reverse_iterator rend() 返回set最后一个元素下一个位置的反向迭代器, 即rbegin
const_reverse_iterator crbegin()const 返回set第一个元素的反向const迭代器,即cend
const_reverse_iterator crend() const 返回set最后一个元素下一个位置的反向const迭 代器,即crbegin

set的容量

函数声明 功能介绍
bool empty ( ) const 检测set是否为空,空返回false,否则返回true
size_type size() const 返回set中有效元素的个数

set的修改

函数声明 功能介绍
pair insert ( const value_type& x ) 在set中插入元素x,实际插入的是构成的 键值对,如果插入成功,返回<该元素在set中的 位置,true>,如果插入失败,说明x在set中已经 存在,返回在set中的位置,false>
void erase ( iterator position ) 删除set中position位置上的元素
size_type erase ( const key_type& x ) 删除set中值为x的元素,返回删除的元素的个数
void erase ( iterator first, iterator last ) 删除set中[first, last)区间中的元素
void swap ( set& st ); 交换set中的元素
void clear ( ) 将set中的元素清空
iterator find ( const key_type& x ) const 返回set中值为x的元素的位置
size_type count ( const key_type& x ) const 返回set中值为x的元素的个数

multiset

它允许存储具有相同值的元素,并且这些元素会根据特定的排序准则自动排序。与 set 容器不同,multiset 允许重复的元素值。

  • multiset的操作大致是一样的唯一的额区别就是,multiset允许有重复的元素。
  • 针对set以下接口,大致是留给multiset
函数声明 功能介绍
lower_bound 返回比这个大于等于这个值的迭代器
upper_bound 返回大于这个值的迭代器
equal_range pair equal_range (const value_type& val) const
返回这个值的区间,满足左闭又开。
  • pair<iterator,iterator>这个返回值是键对值。

map(KV模型)

map是一种关联容器,它存储元素作为键值对(key-value pairs),其中每个键都是唯一的。

map的使用介绍

map的迭代器

函数声明 功能介绍
begin()和end() begin:首元素的位置,end最后一个元素的下一个位置
cbegin()和cend() 与begin和end意义相同,但cbegin和cend所指向的元素不能修改
rbegin()和rend() 反向迭代器,rbegin在end位置,rend在begin位置,其 ++和--操作与begin和end操作移动相反
crbegin()和crend() 与rbegin和rend位置相同,操作相同,但crbegin和crend所 指向的元素不能修改

map的容量与元素访问

函数声明 功能简介
bool empty ( ) const 检测map中的元素是否为空,是返回 true,否则返回false
size_type size() const 返回map中有效元素的个数
mapped_type& operator[] (const key_type& k) 返回去key对应的value
  • 值得注意的是[]由于map存储的值的键值对.

注意:

  • 在元素访问时,有一个与operator[]类似的操作at()(该函数不常用)函数
  • 都是通过 key找到与key对应的value然后返回其引用
  • 不同的是:当key不存在时,operator[]用默认 value与key构造键值对然后插入,返回该默认value,at()函数直接抛异常。

在这里插入图片描述

代码解析

pair<iterator, bool> ret = insert(key, V());
return ret.first->second;
AI 代码解读
  • 如果key存在,则返回这等于key的迭代器。
  • 如果key不存在,在则返回新插入节点的迭代器。

pair

std::pair 是 C++ 标准模板库(STL)中的一个模板结构,用于存储一对值。

在map中是如何赋值:

void TestMap()
{
   
    map<string, string> m;
    string s1("苹果");
    string s2("apple");
    m.insert(pair<string, string>(s1, s2));
    //C++98pair构造
    m.insert(make_pair("桃子", "peach"));
    //C++11 多参数的构造函数隐式类型转换
    m.insert({
    "香蕉","banana" });

    for (auto e : m)
    {
   
        cout << e.first << ":" << e.second << endl;
    }
}
AI 代码解读

map中元素的修改

函数声明 功能简介
pair insert ( const value_type& x ) 在map中插入键值对x,注意x是一个键值对,返回值也是键值对:iterator代表新插入 元素的位置,bool代表释放插入成功
void erase ( iterator position ) 删除position位置上的元素
size_type erase ( const key_type& x ) 删除键值为x的元素
void erase ( iterator first, iterator last ) 删除[first, last)区间中的元素
void swap ( map& mp ) 交换两个map中的元素
void clear ( ) 将map中的元素清空
iterator find ( const key_type& x ) 在map中插入key为x的元素,找到返回该元素的位置的迭代器,否则返回end
const_iterator find ( const key_type& x ) const 在map中插入key为x的元素,找到返回该元素的位置的const迭代器,否则返回cend
size_type count ( const key_type& x ) const 返回key为x的键值在map中的个数,注意 map中key是唯一的,因此该函数的返回值 要么为0,要么为1,因此也可以用该函数来 检测一个key是否在map中

multimap

multimap是C++标准模板库(STL)中的一种关联容器,它存储键值对,并且允许一个键对应多个值。这与map容器不同,后者对于每个键只存储一个值。

函数声明 功能介绍
lower_bound 返回比这个大于等于这个值的迭代器
upper_bound 返回大于这个值的迭代器
equal_range pair equal_range (const value_type& val) const 返回这个值的区间,满足左闭又开。

map和set对比

综上所述map和set很相似,很多接口都一样,区别如下

对比维度 map set
存储元素 键值对 单个值
唯一性 键唯一 元素唯一
访问方式 通过键访问值 通过迭代器遍历
修改能力 可以通过键修改值 元素不可修改
默认排序 键升序 值升序
底层结构 红黑树 红黑树


|
| 访问方式 | 通过键访问值 | 通过迭代器遍历
|
| 修改能力 | 可以通过键修改值 | 元素不可修改
|
| 默认排序 | 键升序 | 值升序
|
| 底层结构 | 红黑树 | 红黑树 |

目录
打赏
0
2
3
1
36
分享
相关文章
【c++丨STL】基于红黑树模拟实现set和map(附源码)
本文基于红黑树的实现,模拟了STL中的`set`和`map`容器。通过封装同一棵红黑树并进行适配修改,实现了两种容器的功能。主要步骤包括:1) 修改红黑树节点结构以支持不同数据类型;2) 使用仿函数适配键值比较逻辑;3) 实现双向迭代器支持遍历操作;4) 封装`insert`、`find`等接口,并为`map`实现`operator[]`。最终,通过测试代码验证了功能的正确性。此实现减少了代码冗余,展示了模板与仿函数的强大灵活性。
30 2
|
13天前
|
【c++丨STL】map/multimap的使用
本文详细介绍了STL关联式容器中的`map`和`multimap`的使用方法。`map`基于红黑树实现,内部元素按键自动升序排列,存储键值对,支持通过键访问或修改值;而`multimap`允许存在重复键。文章从构造函数、迭代器、容量接口、元素访问接口、增删操作到其他操作接口全面解析了`map`的功能,并通过实例演示了如何用`map`统计字符串数组中各元素的出现次数。最后对比了`map`与`set`的区别,强调了`map`在处理键值关系时的优势。
116 73
第二问:C++中const用法详解
`const` 是 C++ 中用于定义常量的关键字,主要作用是防止值被修改。它可以修饰变量、指针、函数参数、返回值、类成员等,确保数据的不可变性。`const` 的常见用法包括:
175 2
|
15天前
|
【c++丨STL】set/multiset的使用
本文深入解析了STL中的`set`和`multiset`容器,二者均为关联式容器,底层基于红黑树实现。`set`支持唯一性元素存储并自动排序,适用于高效查找场景;`multiset`允许重复元素。两者均具备O(logN)的插入、删除与查找复杂度。文章详细介绍了构造函数、迭代器、容量接口、增删操作(如`insert`、`erase`)、查找统计(如`find`、`count`)及`multiset`特有的区间操作(如`lower_bound`、`upper_bound`、`equal_range`)。最后预告了`map`容器的学习,其作为键值对存储的关联式容器,同样基于红黑树,具有高效操作特性。
43 3
哈希表模拟封装unordered_map和unordered_set
哈希表模拟封装unordered_map和unordered_set
|
3月前
|
你对Collection中Set、List、Map理解?
你对Collection中Set、List、Map理解?
91 18
你对Collection中Set、List、Map理解?
只会“有序无序”?面试官嫌弃的List、Set、Map回答!
小米,一位热衷于技术分享的程序员,通过与朋友小林的对话,详细解析了Java面试中常见的List、Set、Map三者之间的区别,不仅涵盖了它们的基本特性,还深入探讨了各自的实现原理及应用场景,帮助面试者更好地准备相关问题。
84 20
【C++】unordered_map(set)
C++中的`unordered`容器(如`std::unordered_set`、`std::unordered_map`)基于哈希表实现,提供高效的查找、插入和删除操作。哈希表通过哈希函数将元素映射到特定的“桶”中,每个桶可存储一个或多个元素,以处理哈希冲突。主要组成部分包括哈希表、哈希函数、冲突处理机制、负载因子和再散列,以及迭代器。哈希函数用于计算元素的哈希值,冲突通过开链法解决,负载因子控制哈希表的扩展。迭代器支持遍历容器中的元素。`unordered_map`和`unordered_set`的插入、查找和删除操作在理想情况下时间复杂度为O(1),但在冲突较多时可能退化为O(n)。
49 5
|
3月前
|
C++
第十三问:C++中静态变量的用法有哪些?
本文介绍了 C++ 中静态变量和函数的用法及原理。静态变量包括函数内的静态局部变量和类中的静态成员变量,前者在函数调用间保持值,后者属于类而非对象。静态函数不能访问非静态成员,但可以通过类名直接调用。静态链接使变量或函数仅在定义文件内可见,避免命名冲突。
109 0

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等