标签: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