map/multimap容器

map基本概念

  • map中的所有元素都是pair
  • pair中的第一个元素是键值(key)起到索引作用,第二个元素是实际值
  • map中的所有元素都会根据键值自动排序

map和multimap属于关联式容器,底层用二叉树实现


关联式容器可以根据key值快速找到value值,平均的时间复杂度只有O(log n)(无序关联容器为O(1))


map中不允许有重复的键值,multimap中允许有重复的键值

map构造和赋值

cpp 复制代码
//默认构造函数
map<T1, T2> mp;
//拷贝构造函数
map<T1, T2>(const map& mp);
//利用重载=赋值
map& operator=(const map& mp);

map容器的大小和交换

cpp 复制代码
//返回容器中元素的个数
int size();
//判断容器是否为空
bool empty();
//交换两个容器的元素
void swap(map& mp);

插入和删除

cpp 复制代码
//插入元素
pair<auto iterator, bool> insert(pair<T1, T2>(key, value);
//清除容器中的所有元素
void clear();
//删除迭代器指向的位置,返回下一个元素的迭代器
iterator erase(iterator pos);
//删除键值为key的元素,返回删除的元素的个数
int erase(key);
//删除beg和end之间的元素(左闭右开),返回下一个元素的迭代器
iterator erase(iterator beg, iterator end);
  • 在map容器中,同样的键值只能存在一个 insert函数的返回值中的布尔类型就是判断是否插入成功。
  • 如果因为相同的键值已经存在而未能插入成功则pair中的迭代器会返回已经存在的拥有同样键值的函数的迭代器。

map容器查找与访问

cpp 复制代码
//查找键值为key的元素并返回其迭代器,若不存在则返回mp.end()
iterator find(key);
//统计容器中键值为key的元素的个数
int count(key);

map容器的读写

cpp 复制代码
//重载了[]运算符,通过键值读写元素
T2& operator[](const T1& key);

若使用 mp[key] = value赋值时对应键值不存在则编译器会自动创建一个key和value键值对给容器

map容器排序

与set容器相同,map容器也可以通过自定义的仿函数改变默认的排序规则或者给自定义的数据类型排序

cpp 复制代码
//通过这个仿函数可以让map对键值的排序变为从大到小
class myCompare
{
public:
	bool operaotr()(int v1, int v2)
	{
	 	return v1 > v2;
	 }
};
//定义map时在模板参数列表中加入该仿函数即可
map<int, int, myCompare> mp;

也可以通过函数指针来改变排序的规则

cpp 复制代码
bool myCompare(int v1, int v2)
{
	return v1 > v2;
}

void test01()
{
	bool(*func_ptr)(int, int);
	func_ptr = myCompare;
	//以上两个步骤也可以直接改为:
	//bool(*)(int, int) func_ptr = myCompare;
	map<int, int, bool(*)(int, int)> mp(func_ptr);
	//这一步等效为:
	//map<int, int,bool(*)(int, int)> mp(func_ptr);
}

在map的模板参数列表中只能声明参数的类型而不能传递具体的实例,像下面的写法就是错误的示范:

cpp 复制代码
map<int, int, func_ptr> mp();
相关推荐
tjl521314_214 小时前
04C++ 名称空间(Namespace)
开发语言·c++
ximu_polaris4 小时前
设计模式(C++)-行为型模式-备忘录模式
c++·设计模式·备忘录模式
流年如夢7 小时前
单链表进阶版 -->双向链表
数据结构·链表
流年如夢9 小时前
单链表 -->增、删、查、改等详细操作
c语言·数据结构
tankeven9 小时前
C++ 智能指针
c++
handler0111 小时前
【算法模板】最小生成树:稠密图选 Prim,稀疏图选 Kruskal
c语言·数据结构·c++·算法
许长安11 小时前
RPC 异步调用基本使用方法:基于官方helloworld-async 示例
c++·经验分享·笔记·rpc
sparEE12 小时前
c++面向对象:对象的赋值
开发语言·c++
此生决int12 小时前
快速复习之数据结构篇——栈和队列
数据结构·c++
昵称小白12 小时前
子串专题部分
数据结构·算法·哈希算法