STL库--pair详解

目录

pair的定义

pair中元素的访问

pair常用函数实例解析

pair的常见用途

pair是一个很实用的小玩意,当想要将两个元素绑在一起作为一个合成元素、又不想要因此定义结构体时,使用pair可以很方便地作为一个代替品。也就是说,pair实际上可以看作一个内部有两个元素的结构体,且这两个元素的类型是可以指定的。

复制代码
struct pair{
	typeName1 first;
	typeName2 second;
};

pair的定义

由于map的内部实现中涉及pair,因此添加map头文件时会自动添加utility头文件,此时如果需要使用pair,就不需要额外再去添加utility头文件。

pair有两个参数,分别对应first和second的数据类型,它们可以任意基本数据类型或容器。

复制代码
pair<typeName1,typeName2> name;

因此,想要定义参数为string和int类型的pair,就可以使用如下写法:

复制代码
pair<string,int> p;

如果想在定义pair时进行初始化,只需要跟上一个小括号,里面填写两个想要初始化的元素即可:

复制代码
pair<string,int> p("haha",5);

而如果想要在代码中临时构建一个pair,有如下两种方法:

(1)将类型定义写在前面,后面用小括号内两个元素的方式

复制代码
pair<string,int> ("haha",5);

(2)使用自带的make_pair函数

复制代码
make_pair("haha",5);

pair中元素的访问

pair中只有两个元素,分别是first和second,只需要按正常结构体的方式去访问即可。

复制代码
#include<iostream>
#include<utility>
#include<string>
using namespace std;
int main(){
	pair<string,int> p;
	p.first="haha";
	p.second=5;
	cout<<p.first<<" "<<p.second<<endl;
	p=make_pair("xixi",55);
	cout<<p.first<<" "<<p.second<<endl;
	p=pair<string,int>("heihei",555);
	cout<<p.first<<" "<<p.second<<endl;
	return 0;
}

输出结果

复制代码
haha 5
xixi 55
heihei 555

pair常用函数实例解析

比较操作数

两个pair类型数据可以直接使用==、!=、<、<=、>、>=比较大小,比较规则是先以first的大小作为标准,只有当first相等时才去判别second的大小

复制代码
#include<cstdio>
#include<utility>
using namespace std;
int main(){
	pair<int,int>p1(5,10);
	pair<int,int>p2(5,15);
	pair<int,int>p3(10,5);
	if(p1<p3){
		printf("p1<p3\n");
	}
	if(p1<=p3){
		printf("p1<=p3\n");
	}
	if(p1<p2){
		printf("p1<p2\n");
	}
	return 0;
}

pair的常见用途

关于pair有两个比较常见的例子:

(1)用来代替二元结构体及其构造函数,可以节省编码时间。

(2)作为map的键值对来进行插入,例如下面的例子:

复制代码
#include<iostream>
#include<string>
#include<map>
using namespace std;
int main(){
	map<string,int> mp;
	mp.insert(make_pair("heihei",5));
	mp.insert(pair<string,int>("haha",10));
	for(map<string,int>::iterator it=mp.begin();it!=mp.end();it++){
		cout<<it->first<<" "<<it->second<<endl;
	}
	return 0;
}
相关推荐
mit6.82424 分钟前
并查集|栈
c++
中国胖子风清扬30 分钟前
Rust 序列化技术全解析:从基础到实战
开发语言·c++·spring boot·vscode·后端·中间件·rust
j_xxx404_39 分钟前
数据结构:栈和队列力扣算法题
c语言·数据结构·算法·leetcode·链表
南莺莺43 分钟前
假设一个算术表达式中包含圆括号、方括号和花括号3种类型的括号,编写一个算法来判别,表达式中的括号是否配对,以字符“\0“作为算术表达式的结束符
c语言·数据结构·算法·
THMAIL1 小时前
深度学习从入门到精通 - 神经网络核心原理:从生物神经元到数学模型蜕变
人工智能·python·深度学习·神经网络·算法·机器学习·逻辑回归
野犬寒鸦1 小时前
力扣hot100:旋转图像(48)(详细图解以及核心思路剖析)
java·数据结构·后端·算法·leetcode
墨染点香1 小时前
LeetCode 刷题【61. 旋转链表】
算法·leetcode·职场和发展
岁忧1 小时前
(LeetCode 面试经典 150 题) 200. 岛屿数量(深度优先搜索dfs || 广度优先搜索bfs)
java·c++·leetcode·面试·go·深度优先
一枝小雨2 小时前
【OJ】C++ vector类OJ题
数据结构·c++·算法·leetcode·oj题
一枝小雨2 小时前
【C++】Vector完全指南:动态数组高效使用
开发语言·c++·笔记·vector·学习笔记·std库