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;
}

扩展

相关推荐
博笙困了20 小时前
AcWing学习——双指针算法
c++·算法
感哥20 小时前
C++ 指针和引用
c++
感哥1 天前
C++ 多态
c++
沐怡旸2 天前
【底层机制】std::string 解决的痛点?是什么?怎么实现的?怎么正确用?
c++·面试
River4162 天前
Javer 学 c++(十三):引用篇
c++·后端
感哥2 天前
C++ std::set
c++
侃侃_天下2 天前
最终的信号类
开发语言·c++·算法
博笙困了2 天前
AcWing学习——差分
c++·算法
echoarts2 天前
Rayon Rust中的数据并行库入门教程
开发语言·其他·算法·rust
Aomnitrix2 天前
知识管理新范式——cpolar+Wiki.js打造企业级分布式知识库
开发语言·javascript·分布式