STL之Multimap容器和Pair对组

Multimap时map映射容器的一种,其拥有map的全部内容,并在此基础之上,multimap还具有了可以重复保存元素的功能,与上文的mutliset差不多,任何进行访问单个值得语句访问均只会返回第一个位置。

cpp 复制代码
#include <iostream>
#include <string>
#include <map>
using namespace std;
int main() {
	multimap<string, int> m_map;
	string name = "XiaoMing";
	m_map.insert(make_pair(name, 50));
	m_map.insert(make_pair(name, 55));
	m_map.insert(make_pair(name, 60));
	m_map.insert(make_pair("zhangsan", 30));
	//查找name并打印
	int k;
	multimap<string, int>::iterator m;
	m = m_map.find(name);
	for (k = 0; k != m_map.count(name); k++, m++)
	cout << m->first << "--" << m->second << endl;
	return 0;
}

1、什么是Pair对组?

pair只含有两个元素,可以看作是只有两个元素的结构体。对于成对出现的数据,利用对组可以返回两个数据。
在创建pair对象时,必须提供两个类型名,两个对应的类型名的类型不必相同,可以在定义时进行成员初始化。

  • 标准头文件 #include,vs里面,某些编译器可以不声明这个头文件而直接使用,貌似在C++中,pair被放入了std命名空间中了。

2、Pair初始化

格式为:template <class T1, class T2> struct pair;

在现实情况中我们可以像类似于STL创建新容器一样创建pair也可以直接使用,如下:

cpp 复制代码
pair<int,int> p;
cpp 复制代码
pair<int,int> p(10,20);

或者是

cpp 复制代码
map<char,int> m;
cpp 复制代码
m.insert(pair<char,int>('a',10));

3、Pair数据访问

cpp 复制代码
//数据类型 数据
pair<string, int>p("武松", 17);
cout << "姓名:" << p.first << " 年岁:" << p.second << endl;
cpp 复制代码
//和结构体类似,first代表第一个元素,second代表第二个元素
pair<char, float>p1=make_pair('p',3.1415 );
cout << "字符:" << p1.first << " 小数:" << p1.second << endl;

4、make_pair

函数原型template pair make_pair(T1 a, T2 b) { return pair(a, b); }

可以通过make_pair生成我们的所需要的pair,对于一般的pair而言,如果需要对其进行赋值,则需要pair<int,int> p; p.first=10,p.second=20;

但如果使用make_pair方法,则可以变成如下内容:pair<int,int> p; p=make_pair(10,20);

相关推荐
半瓶榴莲奶^_^1 小时前
jvm java虚拟机
java·jvm
Gofarlic_oms15 小时前
利用API实现ANSYS许可证管理自动化集成
运维·服务器·开发语言·matlab·自动化·负载均衡
AI+程序员在路上7 小时前
VS Code 完全使用指南:下载、安装、核心功能与 内置AI 编程助手实战
开发语言·人工智能·windows·开源
invicinble7 小时前
这里对java的知识体系做一个全域的介绍
java·开发语言·python
catchadmin7 小时前
使用 PHP TrueAsync 改造 Laravel 协程异步化的可行路径
开发语言·php·laravel
wbs_scy7 小时前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·开发语言
ss2737 小时前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
AI人工智能+电脑小能手7 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
try2find8 小时前
打印ascii码报错问题
java·linux·前端
014-code8 小时前
CompletableFuture 实战模板(超时、组合、异常链处理)
java·数据库