C++中的STL中有map这一数据类型,其作用就是把两个数据关联起来,下面给出他的实例
#include <map> 这一点必不可少
然后声明map map<int,string> mapStudent; //可以加载为其他的元素都可以
然后插入数据 mapStudent,insert(pair<int,string>(5,"student")); 这种是通过pair方式插入,还有通过value_type方式插入的
这种用法比较简单,方便好记
插入完了之后就是访问,访问是通过一种叫做迭代器的方式
迭代器能够容纳任何数据结构,并且对任何数据结构进行访问,这才是迭代器强大的地方
map<int,string>::iterator iter;
for(iter = mapStudent.begin();iter!=mapStudent.end();iter++){
cout<<iter->first<<" "<<iter->second<<endl; //第一个元素通过iter->first,第二个通过iter->second ,如果是其他类型就按其他类型的走
}
删除用 int n = mapStudent.erase(); 里面放参数
mapStudent强大的地方在哪儿?
mapStudent最强大的地方就是在于它能够将任何两个自定义类型的数据关联起来,这才是它强大的地方
程序实例:
1,
#include <map>
#include <string>
#include <iostream>
Using namespace std;
Int main()
{
Map<int, string> mapStudent;
mapStudent.insert(pair<int, string>(1, “student_one”));
mapStudent.insert(pair<int, string>(2, “student_two”));
mapStudent.insert(pair<int, string>(3, “student_three”));
map<int, string>::iterator iter;
for(iter = mapStudent.begin(); iter != mapStudent.end(); iter++)
{
Cout<<iter->first<<” ”<<iter->second<<end;
}
}
2,
#include <map>
#include <string>
#include <iostream>
using namespace std;
int main(int argc, char *argv[])
{
map<int,string> mapStudent;
mapStudent.insert(pair<int,string>(7,"student_one"));
mapStudent.insert(pair<int,string>(5,"student_two"));
mapStudent.insert(pair<int,string>(3,"student_three"));
map<int,string>::reverse_iterator iter;
// iter =mapStudent.find(3);
cout<<iter->second<<endl;
// int n = mapStudent.erase(1);
int size = mapStudent.size();
cout<<"size:"<<size<<endl;
for(iter = mapStudent.rbegin();iter!=mapStudent.rend();iter++){
cout<<iter->first<<iter->second<<endl;
}
return 0;
}