C++之pair

转载自:http://www.cnblogs.com/archimedes/p/cpp-pair.html

http://www.cnblogs.com/Nimeux/archive/2010/10/05/1844191.html

std::pair主要的作用是将两个数据组合成一个数据,两个数据可以是同一类型或者不同类型。例如std::pair<int,float> 或者 std::pair<double,double>等。pair实质上是一个结构体,其主要的两个成员变量是first和second,这两个变量可以直接使用。初始化一个pair可以使用构造函数,也可以使用std::make_pair函数,make_pair函数的定义如下:

 1.应用

如果一个函数有两个返回值 的话,如果是相同类型,就可以用数组返回,如果是不同类型,就可以自己写个struct ,但为了方便就可以使用 c++  自带的pair ,返回一个pair,其中带有两个值。除了返回值的应用,在一个对象有多个属性的时候 ,一般自己写一个struct ,如果就是两个属性的话,就可以用pair 进行操作。。。

template pair make_pair(T1 a, T2 b) { return pair(a, b); }
2.标准库类型--pair类型定义在utility头文件中定义

3.声明和初始化

pair包含两个数值,与容器一样,pair也是一种模板类型。但是又与之前介绍的容器不同,在创建pair对象时,必须提供两个类型名,两个对应的类型名的类型不必相同。

声明

pair<string,string>anon;
pair<string,int>word_count;
pair<string, vector<int> >line;

声明并初始化

<pre name="code" class="plain">pair<int ,int >p (5,6);
pair<int ,int > p1= make_pair(5,6);
pair<string,double> p2 ("aa",5.0);
pair <string ,double> p3 = make_pair("aa",5.0);
 pair类型的使用相当的繁琐,如果定义多个相同的pair类型对象,可以
使用typedef简化声明:(其他的自定义类型也可以使用typedef简化定义,如结构体 ) 

typedef pair<string,string> Author;
Author proust("March","Proust");
Author Joy("James","Joy");

4、pair对象的操作

对于pair类,可以直接访问其数据成员:其成员都是公有的,分别命名为first和second,只需要使用普通的点操作符
string firstBook;
if(author.first=="James" && author.second=="Joy")
    firstBook="Stephen Hero";

5、生成新的pair对象

除了构造函数,标准库还定义了一个make_pair函数,由传递给它的两个实参生成一个新的pair对象
pair<string, string> next_auth;
string first,last;
while(cin>>first>>last) {
    next_auth=make_pair(first,last);
    //...
}
还可以用下列等价的更复杂的操作:
next_auth=pair<string,string>(first,last);
由于pair的数据成员是公有的,因而可如下直接地读取输入:
pair<string, string> next_auth;
while(cin>>next_auth.first>>next_auth.last) {
    //...
}
5.DEMO

#include<iostream>
#include<string>
#include<vector>
#include<utility>
using namespace std;

int main()
{
    pair<string, int>p;
    typedef vector< pair<string, int> > VP;
    VP vp;
    while(cin>>p.first>>p.second)
    {
        vp.push_back(make_pair(p.first,p.second));
        
    }
    VP::iterator it;
    for(it=vp.begin(); it!=vp.end(); it++)
        cout<<it->first<<","<<it->second<<endl;

    return 0;
}




<think>嗯,用户想知道C++中std::pair类型定义和用法。首先,我得回忆一下std::pair的基本概念。std::pair是一个模板类,可以存放两个不同类型的元素。对的,它的定义在<utility>头文件中,所以使用时需要包含这个头文件。 接下来,类型定义部分。模板类应该有两个类型参数,比如template<typename T1, typename T2> struct pair。用户可能需要具体的例子来说明如何定义,比如std::pair<int, double>。然后,构造函数的几种方式,默认构造、使用两个值初始化、复制构造这些都要提到。 然后是初始化方法,直接初始化、make_pair函数,还有C++17的结构化绑定。这些用法对用户来说可能比较实用,特别是make_pair在泛型编程中的便利性。结构化绑定可以简化代码,提高可读性,这个应该举例子说明。 用法示例部分,可能需要提到std::pair在返回多个值时的应用,比如函数返回一个pair包含结果和状态。还有在容器中的应用,比如map的每个元素都是pair类型。另外,算法中的使用,比如需要返回两个迭代器的情况,像equal_range。 用户提供的引用中有提到std::pair和std::optional的结合使用,这个可能需要解释一下,比如当其中一个元素可能不存在时,用optional来包装。不过用户的问题主要是在类型定义和基本用法,所以这部分可以作为高级用法提一下。 另外,引用中的性能考虑,比如循环中创建拷贝的问题,可能和pair的使用相关吗?比如在遍历容器时,如果元素是pair,使用引用避免拷贝。不过用户的问题可能不涉及性能,但可以简要提及最佳实践。 需要确保回答结构清晰,分点说明,类型定义、初始化方法、常用场景、高级用法等部分。同时,生成的相关问题要围绕pair的扩展应用、性能优化、与其他类型的结合,比如optional或tuple的区别。 可能用户是C++初学者,或者正在使用pair遇到问题,需要了解基本用法和常见场景。需要确保回答准确,同时提供足够的示例代码,比如如何定义、初始化、访问成员,以及在map中的使用例子。 最后,检查LaTeX格式是否正确,行内公式用$...$,独立公式用$$...$$,但这个问题可能涉及较少的数学公式,主要是代码示例。不过如果有提到模板参数,可以用行内公式表示,比如template<typename $T1$, typename $T2$>。 总之,组织内容时要先介绍类型定义,再讲初始化方法,然后常用场景,高级用法,最后相关问题和引用部分。确保每个部分都有代码示例,并正确引用用户提供的资料。</think>### C++中`std::pair`的类型定义与用法 #### 1. **类型定义** `std::pair`是C++标准库中定义的一个模板类,用于存储两个不同类型的值。其基本类型定义如下: ```cpp template<typename T1, typename T2> struct pair { T1 first; T2 second; // 构造函数及其他成员函数 }; ``` 它通过两个模板参数`T1`和`T2`指定成员的类型,例如: - `std::pair<int, double>`:第一个成员为`int`,第二个为`double`; - `std::pair<std::string, bool>`:第一个成员为字符串,第二个为布尔值。 #### 2. **初始化方式** - **直接初始化**: ```cpp std::pair<int, std::string> p1(42, "Hello"); ``` - **使用`make_pair`函数**(自动推导类型): ```cpp auto p2 = std::make_pair(3.14, true); ``` - **列表初始化(C++11+)**: ```cpp std::pair<float, char> p3{3.14f, 'A'}; ``` - **结构化绑定(C++17+)**: ```cpp auto [x, y] = std::make_pair(10, "World"); ``` #### 3. **常用场景** - **函数返回多个值**: ```cpp std::pair<bool, std::string> validate_input(int input) { if (input > 0) return {true, "Valid"}; else return {false, "Invalid"}; } ``` - **作为容器元素**: ```cpp std::map<int, std::string> my_map; my_map.insert(std::make_pair(1, "Apple")); ``` - **算法中的中间结果**: ```cpp auto [min_it, max_it] = std::minmax_element(vec.begin(), vec.end()); ``` #### 4. **高级用法** - **与`std::optional`结合**:当某个值可能不存在时,可以用`std::optional`包装其中一个成员[^1]: ```cpp std::pair<int, std::optional<std::string>> result(42, std::nullopt); ``` - **作为复杂数据结构的键**:例如在`std::unordered_map`中,若键类型为`std::pair`,需自定义哈希函数。 --- ### 代码示例 ```cpp #include <iostream> #include <utility> #include <map> int main() { // 初始化pair std::pair<int, std::string> p(1, "Apple"); std::cout << p.first << ": " << p.second << std::endl; // 输出 1: Apple // 在map中使用pair std::map<int, std::string> fruits; fruits.insert(std::make_pair(2, "Banana")); for (const auto& [key, value] : fruits) { std::cout << key << ": " << value << std::endl; // 输出 2: Banana } return 0; } ``` --- §§ 相关问题 §§ 1. `std::pair`与`std::tuple`的主要区别是什么? 2. 如何为`std::pair`自定义哈希函数以便在无序容器中使用? 3. 在性能敏感的场景中,如何避免`std::pair`的拷贝开销[^3]? 4. `std::pair`如何与结构化绑定(C++17)结合使用? : 结合`std::optional`的用法可处理可能缺失的值。 : 循环中避免拷贝时,可通过引用或移动语义优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值