插入的四种方式:
//会按照key进行排序
map<int, int> m1;
//插入方式
//1.
m1.insert(pair<int, int>(2, 520));
//2.
m1.insert(make_pair(1, 2333));
//3.
m1.insert(map<int, int>::value_type(0, 12345));
//4.
m1[3] = 55555;
访问容器里面元素的两种方式: 区别:
void print(map<int, int>& m1)
{
//可以通过[]里面的key值访问到value值
for (int i = 0; i <m1.size(); i++)
{
cout <<"key值为"<<i<<"的元素的value值: " <<m1[i] << endl;
}
}
void print2(map<int, int>& m)
{
for (map<int, int>::iterator it = m.begin(); it != m.end(); it++)
{
cout << "key值为" <<(*it).first << " value值: " << (*it).second << endl;
}
}
注意: 如果访问key值不存在,会默认value值为0
cout << "m1[4]= " << m1[4] << endl;
删除元素的两种方式:
//会按照key进行排序
map<int, int> m1;
//插入方式
m1.insert(make_pair(1, 1));
m1[2] = 2;
m1[3] = 3;
//删除某个元素
//方式1: 填入key值
m1.erase(2);
//方式2: 填入迭代器
//m1.begin()不能+1,+2
map<int, int>::iterator it = m1.begin();
//后置加加删除当前迭代器,再加一
//前置加加先将迭代器位置加1,再删除
m1.erase(++it);
//方式3:填入某段区间,迭代器
m1.erase(m1.begin(), m1.end());
print2(m1);
清空容器:
//清空容器:
m1.clear();