【C++进阶】pair容器

这篇具有很好参考价值的文章主要介绍了【C++进阶】pair容器。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

👦个人主页:@Weraphael
✍🏻作者简介:目前学习C++和算法
✈️专栏:C++航路
🐋 希望大家多多支持,咱一起进步!😁
如果文章对你有帮助的话
欢迎 评论💬 点赞👍🏻 收藏 📂 加关注✨


一、什么是pair

假设我想打包两种数据,第一个是学生的姓名,第二个是学生的学号,我们就可以写出如下结构体:

#include <string>

struct Student
{
	std::string _name; // 名字
	int _id; // 学号
};

像这样只打包两种数据,我们就可以使用std::pairpair的中文意思一对,也就是说它只能保存一对数据

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

pair是C++已经定义好的结构体,同时也是一个类模板,并且使用前需要加上头文件<utility>

【pair部分源码】

template <class T1, class T2>
struct pair
{
	typedef T1 first_type;
	typedef T2 second_type;
	
	T1 first;
	T2 second;
	pair(): first(T1()), second(T2())
	{}
	pair(const T1& a, const T2& b): first(a), second(b)
	{}
}

通过以上源码我们发现:pair有两个公有成员变量,分别是:firstsecond。并且它们可以直接在类外被使用。

【声明方式】

类模板实例化对象需要加上<>

std::pair<第一个数据类型,第二个数据类型> 变量名

接下来我用代码演示 一下刚才的学生结构体

#include <iostream>
#include <utility>
#include <string>

int main()
{
    // 第一个数据类型为string,表示学生的姓名
    // 第二个数据类型为int,表示学生的学号
    std::pair<std::string, int> stu;

    stu.first = "Weraphael";
    stu.second = 2022;

    std::cout << "姓名:" << stu.first << std::endl;
    std::cout << "学号:" << stu.second << std::endl;

    return 0;
}

【运行结果】

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

二、pair的初始化

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

pair常见的初始化是以上第一种和第二种,分别是默认构造和拷贝构造

  • 注意:如果使用默认构造函数初始化,其成员变量firstsecond的值是0(如果是string就是空字符串)

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

  • 除此之外,还有第三种初始化方式
std::pair<类型1, 类型2> 变量名(第一个数据的初始值, 第二个数据的初始值);
// 对应的类型一定要匹配!!!

【代码演示】

#include <iostream>
#include <utility>
#include <string>

int main()
{
    std::pair<std::string, int> p("Weraphael", 18);

    std::cout << "姓名:" << p.first << std::endl;
    std::cout << "年龄:" << p.second << std::endl;

    return 0;
}

【程序结果】

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

三、pair的大小比较

它们的比较顺序是这样的:首先先比较first成员变量,如果相等就会比较second

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

注意:pair内部成员的类型不一样的两个对象不能比较大小!!!

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

【代码验证】

pair内部已经实现过比较大小运算符重载了

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

#include <iostream>
#include <utility>
#include <string>

int main()
{
    std::pair<int, std::string> p1(18, "Weraphael");
    std::pair<int, std::string> p2(19, "Weraphael");

    std::cout << "p1是否小于p2:" << (p1 < p2) << std::endl;

    std::pair<int, std::string> p3(18, "zhangsan");
    std::cout << "p1是否小于p3:" << (p1 < p3) << std::endl;

    std::pair<int, std::string> p4(18, "Weraphael");
    std::cout << "p1是否等于p4:" << (p1 == p4) << std::endl;

    return 0;
}

【运行结果】

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

四、make_pair函数

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

功能:make_pair函数接收两个参数,然后它会将这两个参数来创建pair对象

【代码样例】

#include <iostream>
#include <utility>
#include <string>

int main()
{
    std::pair<int, int> p = std::make_pair(1, 2);

    std::cout << "first:" << p.first << std::endl;
    std::cout << "second:" << p.second << std::endl;

    return 0;
}

【程序结果】

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

以上我们发现:用了make_pair函数后,代码变长了。但是实际上,make_pair函数是用来简化代码的

从C++到C++17,结构体创建对象的代码一直都在简化。我们可以看C++98是如何简化pair创建对象的代码的:

  • 有两个long long类型的变量,现需要通过一个打印函数,将这两个变量打包成pair后再打印

如果不使用make_pair函数,就会写出以下代码

#include <iostream>
#include <utility>

void Print(std::pair<long long, long long> p)
{
    std::cout << "first:" << p.first << std::endl;
    std::cout << "second:" << p.second << std::endl;
}

int main()
{
    long long a = 1;
    long long b = 2;

    Print(std::pair<long long, long long>(a, b));

    return 0;
}

【运行结果】

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记

但是用了make_pair函数后,以上代码就会简化很多

#include <iostream>
#include <utility>

void Print(std::pair<long long, long long> p)
{
    std::cout << "first:" << p.first << std::endl;
    std::cout << "second:" << p.second << std::endl;
}

int main()
{
    long long a = 1;
    long long b = 2;

    Print(std::make_pair(a, b));

    return 0;
}

【运行结果】

【C++进阶】pair容器,C++,c++,开发语言,list,c语言,笔记


注:以上知识是为了为map容器打基础!!!文章来源地址https://www.toymoban.com/news/detail-729076.html

到了这里,关于【C++进阶】pair容器的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • c++中的list容器讲解

    c++中的list容器讲解

    list的文档介绍 list是可以在常数范围内在任意位置进行插入和删除的序列式容器,并且该容器可以前后双向迭代。 list的底层是双向链表结构,双向链表中每个元素存储在互不相关的独立节点中,在节点中通过指针指向 其前一个元素和后一个元素。 list与forward_list非常相似:

    2024年02月09日
    浏览(6)
  • 【C++ 学习 ⑬】- 详解 list 容器

    【C++ 学习 ⑬】- 详解 list 容器

    目录 一、list 容器的基本介绍 二、list 容器的成员函数 2.1 - 迭代器 2.2 - 修改操作 三、list 的模拟实现 3.1 - list.h 3.2 - 详解 list 容器的迭代器 3.2 - test.cpp   list 容器以类模板 listT(T 为存储元素的类型)的形式定义在 list 头文件中,并位于 std 命名空间中 。 list 是序列容器,允

    2024年02月12日
    浏览(9)
  • 【C++】list容器功能模拟实现

    【C++】list容器功能模拟实现

            上一次介绍了list队容器的迭代器模拟,这次模拟实现list的简单功能,尤其要注意 构造函数、析构函数、以及赋值运算符重载 的实现。         list容器需要接纳所有类型的数据,因此,结构设置与迭代器设置同理,需要引入结点,数据。     //结点结构     templ

    2024年01月24日
    浏览(7)
  • 【C++学习】STL容器——list

    【C++学习】STL容器——list

    目录 一、list的介绍及使用 1.1 list的介绍  1.2 list的使用 1.2.1 list的构造  1.2.2  list iterator的使用 1.2.3 list capacity 1.2.4 list element access 1.2.5 list modifiers 1.2.6 list 迭代器失效 二、list的模拟实现 2.1 模拟实现list 三、list和vector的对比 一、list的介绍及使用 1.1 list的介绍 list的文档介绍

    2024年02月14日
    浏览(8)
  • C++高级编程——STL:list容器、set容器和map容器

    本专栏记录C++学习过程包括C++基础以及数据结构和算法,其中第一部分计划时间一个月,主要跟着黑马视频教程,学习路线如下, 不定时更新,欢迎关注 。 当前章节处于: ---------第1阶段-C++基础入门 ---------第2阶段实战-通讯录管理系统, ---------第3阶段-C++核心编程, -----

    2024年01月25日
    浏览(8)
  • C++ ——STL容器【list】模拟实现

    C++ ——STL容器【list】模拟实现

    代码仓库: list模拟实现 list源码 数据结构——双向链表 源码的list是双向带头循环链表,所以我们定义两个节点,一个指向下一个,一个指向前一个 list类包含一个 _head 头节点,然后为了方便查出当前有多少个节点,还能多定义一个 _size 源码的迭代器设置了三个模板参数:

    2024年02月15日
    浏览(13)
  • 【C++杂货铺】详解list容器

    【C++杂货铺】详解list容器

    目录 🌈前言🌈 📁 介绍 📁 使用  📂 构造  📂 迭代器iterator  📂 capacity  📂 modifiers  📂 迭代器失效 📁 模拟实现  📂 迭代器的实现 📂 代码展示 📁 和vector的区别 📁 总结         欢迎收看本期【C++杂货铺】,本期内容将讲解STL中关于list的内容,会分为一下几个方

    2024年04月14日
    浏览(9)
  • 【C++】list链表容器功能模拟实现

    目录 介绍 一,容器的结构设计 二,构造函数与赋值运算符 三,析构函数 四,list容器接口 1,begin和end 2,insert和erase 3,其它常用接口函数         上一次介绍了list双向链表容器的迭代器模拟,这次模拟实现list的简单功能,尤其要注意 构造函数、析构函数、以及赋值运算

    2024年02月20日
    浏览(9)
  • C++容器(vector、deque、list、map)

    C++容器(vector、deque、list、map)

    数组尾部添加或删除元素非常迅速。但在中部或头部就比较费时。 *代码演示:* 取: at在下标越界时会抛出异常,我们能捕获异常进行处理;而[]下标越界会让程序直接终止; 构造函数: cbegin, cend, crbegin, crend返回的是常量迭代器,不能通过迭代器修改vector元素的值。 插入(

    2024年02月02日
    浏览(12)
  • C++——STL标准模板库——容器详解——list

    C++——STL标准模板库——容器详解——list

    list:双向链表。list是一种分布式存储的线性表,每个节点分为数据域和指针域,其中指针域中包含一个指向前驱节点的指针和一个指向后续节点的指针,基本模型如下: 1、双向链表:每个元素都有一个前驱和一个后继,这种结构允许在链表的任何位置实现快速的插入和删除

    2024年01月16日
    浏览(9)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包