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

扩展

相关推荐
望获linux18 分钟前
【Linux基础知识系列】第六十四篇 - 了解Linux的硬件架构
linux·运维·服务器·开发语言·数据库·操作系统·嵌入式软件
一匹电信狗28 分钟前
【C++】手搓一个STL风格的vector容器
c语言·数据结构·c++·算法·leetcode·stl·visual studio
重启的码农1 小时前
深入fecal实现 (6) 伽罗瓦域 GF(256) 运算
c++·网络协议
重启的码农1 小时前
深入fecal实现 (2) 编码器 (Encoder)
c++·网络协议
1candobetter1 小时前
JAVA后端开发——用 Spring Boot 实现定时任务
java·开发语言·spring boot
逝雪Yuki1 小时前
Leetcode——11. 盛最多水的容器
c++·算法·leetcode·双指针
小徐不徐说2 小时前
深入理解 Qt 信号与槽机制的底层逻辑
数据库·c++·qt·面试
大梦谁先行2 小时前
Qt写游戏脚本/辅助(仅供参考)
c++·qt·游戏
阳光_你好2 小时前
C++中析构函数为什么需要是虚函数
c++
啊阿狸不会拉杆2 小时前
《Java 程序设计》第 8 章 - Java 常用核心类详解
java·开发语言·python·算法·intellij-idea