标签:line 位置 函数 分析 string 隐式 top example ring
pair类型提供的操作:
pair<T1,T2> p1; pair<T1,T2> p1(v1,v2); make_pair(v1,v2); p1 < p2; p1 == p2; p.first; p.second;
创建和初始化:
pair<string,string> name; pair<string,vector<int>> data;
以上所有调用pair类型的默认构造函数对其成员进行数值初始化,成员初始化为空或0值
也能在定义时提供初始化式:
pair<string,int> Mike("Mike Brown",26);//这里纠正一个错误。既然first要求string,那么要求的即使一个string类,而不是一个字符串而已。故改动为string("Mike Brown")就能够了。
技巧:
使用typedef简化声明
typedef pair<string,string> name;
name dotcom("is","programmer");
创建与赋值小结代码:
#include<iostream>
#include<utility>
#include<string>
using namespace std;
pair<string,int> p;
int main()
{
string str = "直接复制也能够";
int m =19;
// cin>>p.first>>p.second; 法一
// p.first=str;p.second=m; 法二
p = make_pair(string("ghgfhgfh"),m);//法三
cout<<p.first<<p.second<<endl;
return 0;
}
pair<int, float>(1, 1.1); make_pair(1, 1.1);
// make_pair example
#include <utility> // std::pair
#include <iostream> // std::cout
int main () {
std::pair <int,int> foo;
std::pair <int,int> bar;
foo = std::make_pair (10,20);
bar = std::make_pair (10.5,‘A‘); // ok: implicit conversion from pair<double,char>
std::cout << "foo: " << foo.first << ", " << foo.second << ‘\n‘;
std::cout << "bar: " << bar.first << ", " << bar.second << ‘\n‘;
return 0;
}
bool strict_weak_ordering(const std::pair<int,std::string>a,const std::pair<int,std::string>b)
{ return a.first < b.first; }
int main()
{
using namespace std;
vector<pair<int, string> > vec;
vec.push_back(make_pair<int, string>(5, "hello"));
vec.push_back(make_pair<int, string>(4, "hell"));
vec.push_back(make_pair<int, string>(6, "hello,"));
sort(vec.begin(), vec.end(), strict_weak_ordering);
vector<pair<int, string> >::iterator it = vec.begin(), end = vec.end();
for(;it != end; ++it)
cout<<it->second<<endl;
}
利用vector存储piar类型,并通过sort对各pair类型数据的begin()排序,最后借助迭代器输出pair类型数据的second().
标签:line 位置 函数 分析 string 隐式 top example ring
原文地址:http://www.cnblogs.com/brucemengbm/p/6790246.html