C++:vector里插入pair

1.初始化

vector<pair<int,int>> res;

res的声明:表示建立一个vector容器,容器里面放的是pair<int, int>类型的变量。

2.添加元素

以下变量名res皆表示一个 vector<pair<int,int>>类型的容器。

1)利用push_back和强转类型进行添加元素。

res.push_back(pair<int,int>(10,50));//往容器的最后一个位置里插入(10, 50)

2)利用emplace_back进行添加元素(推荐)

/*相比push_back, emplace_back功能更加强大,不需要显式强制转换类型。*/

res.emplace_back(1, 100);//往容器的最后一个位置插入(1, 100)

3.访问

利用res[i].firstres[i].second进行访问

res.emplace_back(1, 100);

res.emplace_back(2, 200);

cout<<res[0].first<<" "<<res[0].second<<endl;//1, 100

cout<<res[1].first<<" "<<res[2].second<<endl;//2, 200

4.排序

利用sort(res.begin(), res.end())进行排序。

默认规则: 先根据pair.first进行升序排序,如果pair.first相同,再根据pair.second进行升序排序

#include<bits/stdc++.h>
using namespace std;

int main(){
vector<pair<int, int>> res;
res.emplace_back(2, 0);//往容器里添加(2, 0)
res.emplace_back(4, 1);//往容器里添加(4, 1)
res.emplace_back(1, 2);
res.emplace_back(2, 3);
res.emplace_back(5, 4);
res.emplace_back(2, -1);
/*

排序前

2 0

4 1

1 2

2 3

5 4

2 -1

*/
sort(res.begin(), res.end());
/*先根据first进行升序排序,如果first相同,则按照second进行升序排序。*/
for(auto x : res){
cout<<x.first<<" "<<x.second<<endl;
}
/*

排序后

1 2

2 -1

2 0

2 3

4 1

5 4

*/
return 0;
}

扩展

相关推荐
liulilittle9 分钟前
IP校验和算法:从网络协议到SIMD深度优化
网络·c++·网络协议·tcp/ip·算法·ip·通信
眠りたいです21 分钟前
基于脚手架微服务的视频点播系统-播放控制部分
c++·qt·ui·微服务·云原生·架构·播放器
耶啵奶膘34 分钟前
uni-app头像叠加显示
开发语言·javascript·uni-app
看海天一色听风起雨落41 分钟前
Python学习之装饰器
开发语言·python·学习
Want5951 小时前
C/C++圣诞树①
c语言·开发语言·c++
老赵的博客1 小时前
c++ 杂记
开发语言·c++
jimmy.hua1 小时前
[C++刷怪笼]:set/map--优质且易操作的容器
开发语言·c++
tan180°1 小时前
Boost搜索引擎 网络库与前端(4)
linux·网络·c++·搜索引擎
bkspiderx2 小时前
C++经典的数据结构与算法之经典算法思想:贪心算法(Greedy)
数据结构·c++·算法·贪心算法
w2sfot2 小时前
Passing Arguments as an Object in JavaScript
开发语言·javascript·ecmascript