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;
}
相关推荐
依旧阳光的老码农22 分钟前
log4cpp 编译说明文档
c++
OpenC++28 分钟前
【C++QT】Layout 布局管理控件详解
c++·经验分享·qt·leetcode
东方翱翔30 分钟前
第十六届蓝桥杯大赛软件赛省赛第二场 C/C++ 大学 A 组
算法·职场和发展·蓝桥杯
Blossom.1181 小时前
量子计算在密码学中的应用与挑战:重塑信息安全的未来
人工智能·深度学习·物联网·算法·密码学·量子计算·量子安全
1白天的黑夜11 小时前
贪心算法-860.柠檬水找零-力扣(LeetCode)
c++·算法·leetcode·贪心算法
BS_Li1 小时前
C++类和对象(上)
开发语言·c++·类和对象
搏博1 小时前
专家系统的基本概念解析——基于《人工智能原理与方法》的深度拓展
人工智能·python·深度学习·算法·机器学习·概率论
yzx9910131 小时前
决策树随机深林
人工智能·python·算法·决策树·机器学习
Y1nhl2 小时前
力扣hot100_子串_python版本
开发语言·python·算法·leetcode·职场和发展
uhakadotcom2 小时前
过来人给1-3 年技术新人的几点小小的建议,帮助你提升职场竞争力
算法·面试·架构