<C++>map 容器快速上手|自定义数据类型排序的避坑理解

这篇具有很好参考价值的文章主要介绍了<C++>map 容器快速上手|自定义数据类型排序的避坑理解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

✅作者简介:热爱后端语言的大学生,CSDN内容合伙人
✨精品专栏:C++面向对象
🔥系列专栏:C++泛型编程


🔥前言

set 容器后,今天总结一下 map 容器的功能,从零到一快速掌握基本使用与常用接口。mapSTL 编程中与 vectorlistset 具有同等重要的地位,键值对的方式存储元素在查找时很是高效,那么下面正式开始 map 容器的学习之旅。

1、map 容器基本操作,从构造到查找统计

1.1、map/ multimap 基本概念

特点:

  • map中所有元素都是二元组pair
  • 二元组中第一个元素为key(键),起到索引作用,第二个元素为value(值)
    • 优点:可以根据key值快速找到value值
  • 所有元素都会根据元素的键值自动升序排序

本质:

  • map/multimap属于关联式容器,底层结构是用二叉树实现

二者区别:

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

1.2、map 赋值和构造

功能:

  • 对map容器进行构造和赋值操作

函数原型:

  • map<T1, T2> mp; 默认构造函数:
  • map(const map &mp); 拷贝构造函数
  • map& operator=(const map &mp); 重载等号操作符

代码示例:

// 遍历容器
void printInfo(map<int,int>& mp)
{
	for (map<int, int>::iterator it = mp.begin(); it != mp.end(); it++) {
		cout << "key = " << it->first << " value = " << it->second << endl;
	}
	cout << endl;
}

// 构造和赋值
void test01()
{
	// 默认构造
	map<int, int> mp1;
	// 利用二元组显示创建
	mp1.insert(make_pair(1,1));
	mp1.insert(make_pair(5,2));
	mp1.insert(make_pair(4,5));
	printInfo(mp1);
	// 拷贝构造
	map<int, int> mp2(mp1);
	printInfo(mp2);
	// 赋值
	map<int, int> mp3;
	mp3 = mp2;
	printInfo(mp3);
}

1.3、map 大小和交换

功能:

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

函数原型:

  • size(); 返回容器中元素的数目
  • empty(); 判断容器是否为空
  • swap(st); 交换两个集合容器

代码示例:

// 大小和交换
void test02()
{
	// 大小
	map<int, int>mp;
	mp.insert(pair<int, int>(1, 10));
	mp.insert(pair<int, int>(3, 30));
	mp.insert(pair<int, int>(2, 20));

	if (mp.empty())
	{
		cout << "m为空" << endl;
	}
	else
	{
		cout << "m的大小为: " << mp.size() << endl;
	}

	// 交换
	map<int, int>m2;
	m2.insert(pair<int, int>(4, 100));
	m2.insert(pair<int, int>(5, 200));
	m2.insert(pair<int, int>(6, 300));

	cout << "交换前" << endl;
	printInfo(mp);
	printInfo(m2);

	cout << "交换后" << endl;
	mp.swap(m2);
	printInfo(mp);
	printInfo(m2);
}

1.4、map 插入和删除

功能:

  • map容器进行插入数据和删除数据

函数原型:

  • insert(elem); 在容器中插入元素。
  • clear(); 清除所有元素
  • erase(pos); 删除pos迭代器所指的元素,返回下一个元素的迭代器。
  • erase(beg, end); 删除区间[beg,end)的所有元素 ,返回下一个元素的迭代器。
  • erase(key); 删除容器中值为key的元素。

代码示例:

// 插入和删除
void test03()
{
	//插入操作
	map<int, int> mp;
	//第一种插入方式
	mp.insert(pair<int, int>(1, 10));
	//第二种插入方式,推荐
	mp.insert(make_pair(2, 20));
	//第三种插入方式
	mp.insert(map<int, int>::value_type(3, 30));
	//第四种插入方式,不推荐:当不存在此值就会自动创建键,值为0
	mp[4] = 40;
	// 模拟误操作
	cout << "下标为6的值为:"<<mp[6] << endl;
	printInfo(mp);

	//删除,按迭代器
	mp.erase(mp.begin());
	printInfo(mp);
	// 删除,按下标
	mp.erase(3);
	mp.erase(6);
	printInfo(mp);

	//清空
	mp.erase(mp.begin(), mp.end());
	mp.clear();
	printInfo(mp);
}

1.5、map 查找和统计

功能:

  • 对map容器进行查找数据以及统计数据

函数原型:

  • find(key); 查找key是否存在,若存在,返回该键对应的迭代器;若不存在,返回end();
  • count(key); 统计key的元素个数

代码示例:

// 查找和统计
void test04()
{
	map<int, int>mp;
	mp.insert(pair<int, int>(1, 10));
	mp.insert(pair<int, int>(2, 20));
	mp.insert(pair<int, int>(4, 40));
	mp.insert(pair<int, int>(3, 30));

	//查找
	map<int, int>::iterator pos = mp.find(3);

	if (pos != mp.end())
	{
		cout << "找到了元素 key = " << (*pos).first << " value = " << (*pos).second << endl;
	}
	else
	{
		cout << "未找到元素" << endl;
	}

	//统计
	int num = mp.count(2);
	cout << "num = " << num << endl;
}

2、自定义排序规则

set 容器一样,定义排序规则需要在创建容器的时候就指定,同样需要借助仿函数,也就是后面会提到的 谓词

2.1、内置数据类型的排序

// 内置数据类型排序
class descmp
{
public:
	bool operator()(int val1, int val2) const {
	    // 指定为降序排列 
		return val1 > val2;
	}
};
void test05()
{
	cout << "降序排序插入:" << endl;
	map<int, int,descmp> mp;
	mp.insert(make_pair(3, 2));
	mp.insert(make_pair(7, 4));
	mp.insert(make_pair(6, 1));
	mp.insert(make_pair(8, 5));
	mp.insert(make_pair(1, 3));

	for (auto it = mp.begin(); it != mp.end(); it++) {
		cout << "key = " << it->first << " value = " << it->second << endl;
	}
}

c++ map自定义类型,C++提高编程,c++,算法,开发语言

仿函数需要指定为 const 常函数类型,否则将会出现数据不完整错误

2.2、自定义数据类型的排序

进行自定义数据类型排序的时候要注意,使用仿函数定义排序规则是针对 的,因此要把定义的类、结构体放在泛型的第一个参数上(别问,问就是我看了半天源码才发现的…)

接下来看看我设计的小案例:

// 自定义数据类型排序
class Hero
{
public:
	// 构造方法
	Hero(string name, int age) :name(name), age(age) {}
	// 属性
	string name;
	int age;
};
class Cmp_hero
{
public:
	bool  operator()(const Hero& h1, const Hero& h2)const {
		return h1.age < h2.age;
	}
};
void test06()
{
	map<Hero, int, Cmp_hero> mh;
	Hero h1("赵云", 42);
	Hero h2("曹操", 43);
	Hero h3("孙策", 39);
	Hero h4("刘备", 40);
	Hero h5("关羽", 41);
	mh.insert(make_pair(h1, 12000));
	mh.insert(make_pair(h2, 14000));
	mh.insert(make_pair(h3, 10000));
	mh.insert(make_pair(h4, 18000));
	mh.insert(make_pair(h5, 16000));

	for (auto t = mh.begin(); t != mh.end(); t++) {
		cout << "姓名:" << t->first.name << " 年龄:" << t->first.age
			<< " 赏金:" << t->second << endl;
	}
}

c++ map自定义类型,C++提高编程,c++,算法,开发语言

其实更合理的设计应该是按照赏金大小来排序,我之所以这样设计是想介绍一下当键是类的时候该怎么处理:仿函数参数列表中的变量若是 引用形式 必须用 const 修饰(若不是引用形式则不用加 const),而且函数也应该是常函数。


map 容器键值对存储的使用是非常广泛的,下篇博客来做一个员工分组的具体案例,巩固一些 STL常用容器的使用,大家可以订阅专栏,方便查阅和复习。文章来源地址https://www.toymoban.com/news/detail-784158.html

到了这里,关于<C++>map 容器快速上手|自定义数据类型排序的避坑理解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【C++】map值自定义key,value排序(含ccfcsp第四次认证第二题演示和map遍历方法)

    sort仅仅支持pair,vector,数组等排序,不支持对map的排序 所以如果想用sort对map排序的话,只需要把map转换为vector即可: 再输出vector,即可得到我们想要的结果 如果想要在map遍历的时候,可以直接输出排序的结果,大不了把原来的map删掉,再把vector的内容重新赋值进去就行了

    2024年02月09日
    浏览(49)
  • [Python物联网]Python基础知识和语法--变量和数据类型--Python快速上手开发物联网上位机程序

    目录 一、前言 二、Python变量 三、Python数据类型         1.数值类型         2.字符串类型         3.列表类型         4.元组类型         5.字典类型         6.数据类型转换         当你开始学习Python编程语言时,第一步就是了解 变量和数据类型 。变量是存储

    2024年02月04日
    浏览(58)
  • STL快速上手1-容器

    STL的六大组成部分 本文章将介绍第一部分,容器的原理与特性 容器(Containers):包括向量(vector)、列表(list)、集合(set)、映射(map)等 算法(Algorithms):包括排序、搜索、合并、交换元素等很多算法 迭代器(Iterators):提供了一种统一的机制来遍历容器中的元素 适配器(Adapters):如stack和q

    2024年02月07日
    浏览(75)
  • 常见排序宝典:帮助快速上手常见基础排序算法(下)

    目录 五、归并排序 1、算法步骤  2、动图演示​编辑  3、代码实现 六、堆排序 1、算法步骤 2、动图演示  3、代码实现 七、快速排序 1、基本思想 2、动图演示 3、代码实现  八、计数排序 1、算法步骤  2、动图演示 ​编辑 3、代码实现  归并排序(MERGE-SORT)是建立在归并操

    2024年04月13日
    浏览(34)
  • 简单易懂的Docker下载安装教程:快速上手容器化应用

    Docker 是一种用于容器化应用程序的开源平台,可以简化应用程序的开发、测试和部署过程。以下是 Docker 在常见操作系统上的下载安装教程。 步骤 1:下载 Docker Desktop 在 Windows 系统上,Docker 提供了一个名为 Docker Desktop 的图形界面工具,可以方便地进行 Docker 安装和管理。在

    2024年02月01日
    浏览(53)
  • 【数据结构与算法】C++的STL模板(迭代器iterator、容器vector、队列queue、集合set、映射map)以及算法例题

    更多算法例题链接: 【数据结构与算法】递推法和递归法解题(递归递推算法典型例题) 什么是迭代器(iterator) 迭代器(iterator)的定义: 迭代器是一种检查容器内元素并遍历元素的数据类型。 迭代器提供对一个容器中的对象的访问方法,并且定义了容器中对象的范围。 容器

    2024年04月14日
    浏览(50)
  • 【C++】map容器

    在C语言中typedef将一个变量提升为一种类型: 在C++中提供了更明确的类型重命名规则using 上面两种类型重命名可以改成: using可以很方便的定义两种类型的集合,如下,将My_Pair的键值对两个类型定义成一个value_type。         value_type是两种类型的集合,使用时给两个类型

    2024年02月08日
    浏览(29)
  • 【C++】map/multimap容器

    2024年02月10日
    浏览(35)
  • C++高级编程——STL:list容器、set容器和map容器

    本专栏记录C++学习过程包括C++基础以及数据结构和算法,其中第一部分计划时间一个月,主要跟着黑马视频教程,学习路线如下, 不定时更新,欢迎关注 。 当前章节处于: ---------第1阶段-C++基础入门 ---------第2阶段实战-通讯录管理系统, ---------第3阶段-C++核心编程, -----

    2024年01月25日
    浏览(47)
  • C++容器(vector、deque、list、map)

    数组尾部添加或删除元素非常迅速。但在中部或头部就比较费时。 *代码演示:* 取: at在下标越界时会抛出异常,我们能捕获异常进行处理;而[]下标越界会让程序直接终止; 构造函数: cbegin, cend, crbegin, crend返回的是常量迭代器,不能通过迭代器修改vector元素的值。 插入(

    2024年02月02日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包