pair 的用法

文章介绍了C++中pair类型的声明、初始化以及如何用make_pair创建pair对象。接着展示了如何对pair数组进行初始化,并通过typedef简化类型声明。在排序部分,讲解了默认按照first排序,以及如何自定义比较函数按照second排序,并给出sort函数的使用示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.pair的声明与初始化 *pair型数组*

pair<T1, T2> p1;         //创建一个空的pair对象(
						
						 
pair<T1, T2> p1(v1, v2);  //其中first成员初始化为v1,second成员初始化为v2。
					 	  
p1=make_pair(v1, v2);     // 以v1和v2的值创建一个新的pair对象,其元素类型分别是v1和v2的类型。
 
p1 < p2;       // 两个pair对象间的小于运算,其定义遵循字典次序,优先排first,first不满足排second,返回bool

p1 == p2;                  // 如果两个对象的first和second都相等
p1.first;                   // 返回对象p1中名为first的公有数据成员
p1.second;                 // 返回对象p1中名为second的公有数据成员
       





//数组
pair<int,int> a[10];
a[0]=make_pair("one",1); //使用make_pair 
a[1]=pair<int,int>("tow",2);//使用对象说明 
typedef pair<string,string> Author; //使用typedef简化声明

2. 排序

用sort()排序,默认按照first的值排序。

如何实现按照second排序

#include<bits/stdc++.h>
using namespace std;
bool cmp(pair<int, int>a, pair<int, int> b)
{
    return a.second < b.second;
}
//根据second的值升序排序
 
int main()
{
	pair<int,int> a[10];
	a[1]=make_pair(1,1);  
	a[0]=pair<int,int>(1,2); 
	
	sort(a,a+2,cmp) ;
	cout<<a[0].first;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值