【C++ STL】 容器详解:pair 学习

在 C++ STL(标准模板库)中,pair 是一个 简单的键值对数据结构,用于存储 两个相关联的值,将两个值组合成一个单元,可以是相同或不同类型。它常用于 返回多个值、存储映射关系、排序 等场景。

1. pair 的基本特点

  • 存储两个值,可以是不同类型。

  • 支持比较运算(按 第一个元素 比较,若相同则比较第二个元素)。

  • 适用于存储键值对或返回多个值

2. pair 的基本用法

2.1 pair 的定义与初始化

// 默认构造函数
pair<int, string> p1;// 带参数的构造函数
pair<int, string> p2(10, "Hello");// 使用make_pair函数
auto p3 = make_pair(20, "World");
//auto 自动识别类型pair<int, string>

pair 本身是一个固定大小的结构,只能存储 两个元素first 和 second),因此不能直接插入多个元素。 

#include <iostream>
#include <utility>  // 包含 pair
using namespace std;int main() {pair<int, string> p1(1, "Apple");pair<int, string> p2 = {2, "Banana"};cout << "p1: (" << p1.first << ", " << p1.second << ")\n";scout << "p2: (" << p2.first << ", " << p2.second << ")\n";return 0;
}

输出:

p1: (1, Apple)
p2: (2, Banana)
pair的内部实现

pair的实现非常简单,它是一个结构体模板,包含两个公有成员firstsecond。以下是pair的简化实现:

template <class T1, class T2>
struct pair {T1 first;T2 second;// 默认构造函数pair() : first(T1()), second(T2()) {}// 带参数的构造函数pair(const T1& x, const T2& y) : first(x), second(y) {}// 拷贝构造函数template <class U1, class U2>pair(const pair<U1, U2>& p) : first(p.first), second(p.second) {}
};

2.2 访问 pair 的元素

pair成员firstsecond可以直接访问

cout << p1.first << " " << p1.second << endl;

2.3 使用 make_pair() 进行初始化

pair<int, double> p = make_pair(10, 3.14);

3. pair 在 STL 容器中的应用

3.1 pair 作为 map 的元素

#include <iostream>
#include <map>
using namespace std;int main() {map<int, string> mp;mp.insert(pair<int, string>(1, "One"));mp.insert(make_pair(2, "Two"));for (auto &p : mp) {cout << p.first << ": " << p.second << endl;}return 0;
}

3.2 pair 作为 vector 的元素

#include <iostream>
#include <vector>
using namespace std;int main() {vector<pair<int, string>> v;v.push_back({1, "Alice"});v.push_back({2, "Bob"});for (auto &p : v) {cout << p.first << " " << p.second << endl;}return 0;
}

3.3 返回多个值

当函数需要返回多个值时,可以使用pair。例如,一个函数可以返回一个pair,其中包含计算结果和状态信息。

#include <iostream>
#include <utility>
using namespace std;pair<int, bool> divide(int a, int b) {if (b == 0) {return make_pair(0, false);  // 返回错误状态}return make_pair(a / b, true);  // 返回结果和成功状态
}int main() {auto result = divide(10, 2);if (result.second) {cout << "Result: " << result.first << endl;} else {cout << "Error: Division by zero" << endl;}return 0;
}

输出:

Result: 5

3.4 作为容器元素

pair可以作为容器的元素,例如vector<pair<int, int>>,用于存储一组相关联的值。

#include <iostream>
#include <vector>
#include <utility>
using namespace std;int main() {vector<pair<int, int>> vec;vec.push_back(make_pair(1, 10));vec.push_back(make_pair(2, 20));for (const auto& p : vec) {cout << "First: " << p.first << ", Second: " << p.second << endl;}return 0;
}//First: 1, Second: 10
//First: 2, Second: 20

4. pair 的比较规则

pair字典序 进行比较:pair支持比较操作(==!=<<=>>=)。

  1. 先比较 first,小者优先。

  2. first 相等,则比较 second

示例:

pair<int, int> a = {1, 5};
pair<int, int> b = {1, 3};
if (a > b) {cout << "a 更大" << endl;
} else {cout << "b 更大" << endl;
}

输出:

a 更大

5. pairtuple 的区别

特性pairtuple
元素个数2任意个
访问方式.first .secondget<n>(tuple)
适用场景键值对、映射关系多个不同类型的数据

 使用 tuple

tuple 是 C++ 标准库中的一个模板类,可以存储多个元素(数量不限)。它的用法类似于pair,但可以容纳更多的元素。

#include <iostream>
#include <tuple> // 包含 std::tuple 的头文件
using namespace std;int main() {// 创建一个包含 3 个元素的 tupletuple<int, string, double> t1(1, "Apple", 3.14);// 访问 tuple 的元素cout << "ID: " << get<0>(t1) << ", Name: " << get<1>(t1) << ", Price: " << get<2>(t1) << endl;return 0;
}

如果你需要存储多个键值对,可以使用 map 或 unordered_map。 

#include <iostream>
#include <map>
using namespace std;int main() {// 创建一个 map,存储多个键值对map<int, string> fruitMap = {{1, "Apple"},{2, "Banana"},{3, "Cherry"}};// 插入新的键值对fruitMap.insert(make_pair(4, "Durian"));// 输出所有键值对for (const auto& entry : fruitMap) {cout << "Key: " << entry.first << ", Value: " << entry.second << endl;}return 0;
}

 

 

6. 总结

pair 是 C++ STL 中 存储两个相关值的简单工具,可广泛用于 映射、排序、返回多个值 等场景。掌握 pair 及其 STL 结合使用方式,可以提高代码的 简洁性可读性

pair最常见的用途是存储键值对。例如,在mapunordered_map中,每个元素都是一个pair,其中first是键,second是值。

#include <iostream>
#include <map>
using namespace std;int main() {map<int, string> myMap;myMap.insert(make_pair(1, "Apple"));myMap.insert(make_pair(2, "Banana"));for (const auto& p : myMap) {cout << "Key: " << p.first << ", Value: " << p.second << endl;}return 0;
}
Key: 1, Value: Apple
Key: 2, Value: Banana

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/34371.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

简述计算机网络中的七层模型和四层模型

在计算机网络中&#xff0c;网络协议栈的设计通常采用分层结构来处理不同的通信任务。常见的分层结构有OSI七层模型和TCP/IP四层模型。虽然它们的层次数量不同&#xff0c;但本质上都在解决如何有效地进行计算机间通信。本文将分别介绍这两种结构的功能和各层的协议。 一、OSI七…

在 CentOS 上安装 Oracle 数据库

文章目录 **1. 系统准备****1.1 检查系统要求****1.2 更新系统****1.3 安装必要的依赖包****1.4 创建 Oracle 用户和组****1.5 配置内核参数****1.6 配置用户限制****1.7 配置 PAM 模块****1.8 创建 Oracle 安装目录** **2. 下载 Oracle 数据库安装包****2.1 访问 Oracle 官方网…

掌握这些 UI 交互设计原则,提升产品易用性

在当今数字化时代&#xff0c;用户对于产品的体验要求越来越高&#xff0c;UI 交互设计成为决定产品成败的关键因素之一。一个易用的产品能够让用户轻松、高效地完成各种操作&#xff0c;而实现这一目标的核心在于遵循一系列科学合理的 UI 交互设计原则。本文将详细阐述简洁性、…

创新实践分享:基于边缘智能+扣子的智能取物机器人解决方案

在 2024 年全国大学生物联网设计竞赛中&#xff0c;火山引擎作为支持企业&#xff0c;不仅参与了赛道的命题设计&#xff0c;还为参赛队伍提供了相关的硬件和软件支持。以边缘智能和扣子的联合应用为核心&#xff0c;参赛者们在这场竞赛中展现出了卓越的创新性和实用性&#xf…

Python----数据可视化(Pyecharts一:介绍安装,全局配置,系列配置)

一、PyEcharts介绍 1.1、概况 Echarts 是一个由百度开源的数据可视化&#xff0c;凭借着良好的交互性&#xff0c;精巧的图表设计&#xff0c;得到了众多开发者的认可。而 Python 是一门富有表达力的语言&#xff0c;很适合用于数据处理。当数据分析遇上数据可视化时&#xff…

Cursor初体验:excel转成CANoe的vsysvar文件

今天公司大佬先锋们给培训了cursor的使用&#xff0c;还给注册了官方账号&#xff01;跃跃欲试&#xff0c;但是测试任务好重&#xff0c;结合第三方工具开发也是没有头绪。 但巧的是&#xff0c;刚好下午有同事有个需求&#xff0c;想要把一个几千行的excel转成canoe的系统变…

【3DGS】SuperSplat本地运行+修改监听端口+导入ply模型+修剪模型+在线渲染3DGS网站推荐

SuperSplat官网代码&#xff1a;https://github.com/playcanvas/supersplat 本地安装和运行 Clone the repository: git clone https://github.com/playcanvas/supersplat.git cd supersplat Install dependencies: npm install Build SuperSplat and start a local web ser…

MySQL中的B+树索引经验总结

一、什么是B树 B树是一种二叉树&#xff0c;由二叉查找树&#xff0c;平衡二叉树&#xff0c;B树演化而来。 请看上图 B树的特点&#xff1a; 1&#xff09;非叶子节点不存放数据&#xff0c;只存放键值&#xff0c;数据都存放在叶子节点中。 2&#xff09;叶子节点都在同一…

C# NX二次开发:在多个体的模型中如何实现拉伸操作布尔减

大家好&#xff0c;今天接着上一篇拉伸文章去讲。 UF_MODL_create_extruded1 (view source) uf_list_p_tobjectsInputList of objects to be extruded.char *taper_angleInputTaper angle (in degrees).char *limit [ 2 ]InputLimit of extrusion. This is declared as: char …

【深度学习】多源物料融合算法(一):量纲对齐常见方法

目录 一、引言 二、量纲对齐常见方法 2.1 Z-score标准化Sigmoid归一化 2.2 Min-Max 归一化 2.3 Rank Transformation 2.4 Log Transformation 2.5 Robust Scaling 3、总结 一、引言 类似抖音、快手、小红书等产品的信息流推荐业务&#xff0c;主要通过信息流广告、信…

前端高级CSS用法

前端高级CSS用法 在前端开发中&#xff0c;CSS&#xff08;层叠样式表&#xff09;不仅是用来控制网页的外观和布局&#xff0c;更是实现复杂交互和动态效果的关键技术之一。随着前端技术的不断发展&#xff0c;CSS的用法也日益丰富和高级。本文将深入探讨前端高级CSS的用法&a…

How to install a package in offline scenario in Ubuntu 24.04

概述 做过信创项目的兄弟们在工作上每天可能面对很多需要解决的问题&#xff0c;不过&#xff0c;有一类问题可能是大家经常遇的&#xff0c;比方说&#xff0c;有时候我们不得不硬着头皮在离线生产环境中安装某些软件包&#xff0c;相信很多兄弟被这种细碎的小事搞得焦头烂额…

C++类与对象——拷贝构造与运算符重载

拷贝构造函数和赋值运算符重载就是C类默认六个函数之二。 拷贝构造函数&#xff1a; 如果⼀个构造函数的第⼀个参数是自身类类型的引用&#xff0c;且任何额外的参数都有默认值&#xff0c;则此构造函数 也叫做拷贝构造函数&#xff0c;也就是说拷贝构造是⼀个特殊的构造函数…

数学建模 第一节

目录​​​​​​ 前言 一 优化模型的类型 二 线性规划1 线性规划2 三 0-1规划 总结 前言 数学建模主要是将问题转化为模型&#xff0c;然后再以编程的形式输出出来 算法都知道&#xff0c;数学建模也需要用到算法&#xff0c;但是不是主要以编程形式展示&#xff0c;而是…

计算机网络——DNS

一、什么是DNS&#xff1f; DNS&#xff08;Domain Name System&#xff0c;域名系统&#xff09; 是互联网的核心服务&#xff0c;负责将人类可读的域名&#xff08;如 www.baidu.com&#xff09;转换为机器可识别的 IP地址&#xff08;如 14.119.104.254&#xff09;。它像一…

【软考-架构】5.2、传输介质-通信方式-IP地址-子网划分

✨资料&文章更新✨ GitHub地址&#xff1a;https://github.com/tyronczt/system_architect 文章目录 传输介质网线光纤无线信道 通信方式和交换方式会考&#xff1a;交换方式 &#x1f4af;考试真题第一题第二题 IP地址表示子网划分&#x1f4af;考试真题第一题第二题 传输…

基于SpringBoot+Vue的毕业论文管理系统+LW示例参考

1.项目介绍 系统角色&#xff1a;管理员、指导教师、评阅教师、学生功能模块&#xff1a;用户管理、毕业论文管理、课题信息管理、选题申请管理、课题任务管理、基础数据管理、公告信息管理、评阅教师管理、指导教师管理等技术选型&#xff1a;SpringBoot&#xff0c;Vue等测试…

文件系统 linux ─── 第19课

前面博客讲解的是内存级文件管理,接下来介绍磁盘级文件管理 文件系统分为两部分 内存级文件系统 : OS加载进程 ,进程打开文件, OS为文件创建struct file 和文件描述符表 ,将进程与打开的文件相连, struct file 内还函数有指针表, 屏蔽了底层操作的差异,struct file中还有内核级…

第十次CCF-CSP认证(含C++源码)

第十次CCF-CSP认证 分蛋糕满分题解 学生排队满分题解 Markdown语法题目解读满分代码 结语 分蛋糕 题目链接 满分题解 基本思路&#xff1a;我们需要保证除了最后一个小朋友之外的所有人&#xff0c;分得的蛋糕都大于等于给定的K值&#xff0c;为什么是大于等于&#xff0c;是…

MyBatis框架操作数据库一>xml和动态Sql

目录 配置连接字符串和MyBatis:数据库的连接配置&#xff1a;XML的配置&#xff1a; XML编写Sql:model层&#xff1a;mapper层&#xff1a; 动态Sql:if 标签和trim标签&#xff1a;where标签:Set标签:Foreach标签: Mybatis的开发有两种方式&#xff1a;&#xff1a; 注解和XML&…