pair 的常见用法详解
2021/9/7 23:37:54
本文主要是介绍pair 的常见用法详解,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
pair 实际上可以看作一个内部有两个元素的结构体,且这两个元素的类型是可以指定的,如:
struct pair { typeName1 first; typeName2 second; };
1.定义:
要使用 pair ,应先添加头文件 #include <utility> ,并在头文件下面加上“ using namespace std;”,然后就可以使用了。注意:由于map 的内部实现中涉及 pair, 因此添加map 头文件时会自动添加 utility 头文件 ,此时如果需要使用 pair ,就不需要额外再去添加 utility 头文件了。pair 有两个参数,分别对应 first 和 second 的数据类型,他们可以是任意基本数据类型或容器。
2.pair 中元素的访问:
/* pair<typeName1,typeName2> name; 因此想要定义 pair 时进行初始化,只需要跟上一个小括号 里面填写两个想要初始化的元素: pair<string,int> p("haja",5); 而如果想在代码中临时构建一个 pair ,有两种方式: 1). 将类型定义写在前面,后面用小括号内两个元素的方式: pair<string,int> ("hsif",5); 2). 使用自带的 make_pair 函数 make_pair("shdoi",5); */ #include<iostream> #include<utility> #include<string> using namespace std; int main() { pair<string,int> p; p.first="ahfkl"; p.second=5; cout<<p.first<<" "<<p.second<<endl; p=make_pair("sndkj",55); cout<<p.first<<""<<p.second<<endl; p=pair<string,int>("shojd",5); cout<<p.first<<" "<<p.second<<endl; return 0; }
3.pair 常用函数实例解析:
比较操作数,两个pair类型数据可以直接使用 “==,!=,<,<=,>,>=》”比较大小,比较规则是先以 first 的大小作为标准,只有当 first 相等时才去判别 second 的大小。
#include<iostream> #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) cout<<"p1<p3\n"; if(p1<=p3) cout<<"p1<=p3\n"; if(p1<p2) cout<<"p1<p2\n"; return 0; }
4.pair 的用途:
1).用来代替二元结构体及其构造函数,可以节省编码时间
2).作为map的键值对来进行插入,
#include<iostream> #include<string> #include<map> using namespace std; int main() { map<string,int> mp; mp.insert(make_pair("skosj",5)); mp.insert(pair<string,int>("dsjhisd",10)); for(map<string,int>::iterator it=mp.begin();it!=mp.end();it++) { cout<<it->first<<" "<<it->second<<endl; } return 0; }
这篇关于pair 的常见用法详解的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-06-15史上最强 AI 翻译诞生了!拳打谷歌,脚踢 DeepL
- 2024-05-29蓝桥杯大赛单片机比赛经验总结
- 2024-05-29AI 一键生成高清短视频,视频 UP 主们卷起来...
- 2024-05-29打造 AI “看牙”新体验,当 Serverless 遇上口腔医疗
- 2024-05-27取代或转型?人工智能对软件测试的影响(内附工具推荐)
- 2024-05-14让创意在幻觉中肆虐: 认识Illusion Diffusion AI
- 2024-05-08Sora从入门到入门-白话版1
- 2024-05-082024年github开源top100中文
- 2024-05-083、最大池化maxinmum pooling
- 2024-05-08动态规划基础思想