Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力。
数据的插入:
#include<map>
map<int,string>student;
strdent.insert(pair<int,string>(1,"XiaoMing"));
strdent.insert(pair<int,string>(2,"XiaoHong"));
//迭代器
map<int,string>::iterator iter;
for(iter=strdent.begin();iter!=student.end();iter++)
{
cout<<iter->first<<" "<<iter->second<<endl;
}
数据大小通过size()函数获得。
数据的查找:使用find()函数,返回的是一个迭代器,若无所找数据,则返回end的迭代器
map<int,string>::iterator iter;
iter=student.find(1);
if(iter!=student.end())
{
cout<<"Find,the value is"<<iter->second<<endl;
}
else
{
cout<<"Do not find"<<endl;
}
数据的清空用clear(),判定map中是否有数据可以用empty()函数,若返回为true则说明为空。
数据的删除:用erase()函数
map<int ,string>::iterator iter;
iter=student.find(1);
student.erase(iter);
//或者使用关键字删除
int n=student.erase(1);//删除了则返回1,否则返回0
我就因为第一个关键字不能重复这个事,纠结一个程序纠结了好几天,最后发现是因为好多数据因为相同被替代了,都疯了要!!!!以后要注意!!!!