C++ pair 的使用

pair的作用

C++ 中的 std::pair 是标准模板库 (STL) 提供的一个容器,它能够存储两个不同类型的数据作为一个整体,其中first:访问 pair 的第一个元素。second:访问 pair 的第二个元素。

复制代码
int main() {
    pair<string, int> p;
    //通过构造函数参数列表初始化
    p = make_pair("张三", 18);
    cout<<p.first << p.second<<endl;//打印结果 张三18
    // 初始化的时候赋值
    pair<string, int> pname("张三", 18);
    cout<<pname.first << pname.second<<endl;//打印结果 张三18
    return 0;
}

使用typedef

复制代码
#include <iostream>
#include <string>
using namespace std;
typedef pair<string,int> pp;
pp p1 = make_pair("张三", 18);
pp p2("张三", 18);
int main() {
     cout<<p1.first << p1.second<<endl;
     cout<<p2.first << p2.second<<endl;
    return 0;
}

pair 用在结构体中

复制代码
#include <iostream>
#include <string>
using namespace std;
struct config{
    pair<string, int> p;
    // 构造函数初始化
    config() : p{"张三", 18} {
        cout<<p.first << p.second<<endl;
    }
 };

int main() {
    config c;
    return 0;
}

还可以pair 与结构体绑定

复制代码
#include <iostream>
#include <string>
using namespace std;

struct config{
    pair<string, int> p;
    // 构造函数初始化
    config() : p{"张三", 18} {
        cout<<p.first << p.second<<endl;
    }
 };

int main() {
    config c;
    // 直接访问config结构体内的pair成员
    std::cout << "Integer value: " << c.p.second << ", String value: " << c.p.first << std::endl;
    // 或者利用C++17的结构化绑定来访问
    auto &[strValue, intValue] = c.p;
    std::cout << "Integer value: " << intValue << ", String value: " << strValue << std::endl;
    return 0;
}

pair 还可以用来 拷贝、赋值和比较

复制代码
std::pair<int, std::string> copyOfPair(myPair); // 拷贝构造
copyOfPair = anotherPair; // 赋值操作

if (myPair == anotherPair) { // 使用内置的等于运算符进行比较
    // ...
}
相关推荐
毕设源码-邱学长9 分钟前
【开题答辩全过程】以 基于Java企业人事工资管理系统为例,包含答辩的问题和答案
java·开发语言
颜*鸣&空1 小时前
QT程序实现串口通信案例
开发语言·qt
无限进步_1 小时前
C语言动态内存的二维抽象:用malloc实现灵活的多维数组
c语言·开发语言·数据结构·git·算法·github·visual studio
froginwe112 小时前
Maven 仓库概述
开发语言
二川bro2 小时前
Python在AI领域应用全景:2025趋势与案例
开发语言·人工智能·python
CoderYanger3 小时前
优选算法-队列+宽搜(BFS):72.二叉树的最大宽度
java·开发语言·算法·leetcode·职场和发展·宽度优先·1024程序员节
招摇的一半月亮3 小时前
P2242 公路维修问题
数据结构·c++·算法
疏狂难除3 小时前
随便玩玩lldb (二)
开发语言·后端·rust
星轨初途3 小时前
数据结构排序算法详解(5)——非比较函数:计数排序(鸽巢原理)及排序算法复杂度和稳定性分析
c语言·开发语言·数据结构·经验分享·笔记·算法·排序算法