map容器的插入和刪除
阿新 • • 發佈:2021-02-15
技術標籤:stl學習之map容器
插入的四種方式:
//會按照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;
訪問容器裡面元素的兩種方式:
區別:
- 第一種方式訪問,如果key0的值不存在,而key1的值存在,在輸出的時候會自動建立一個新的對組,key為0,value值預設為0
- 第二種方式訪問,只會輸出當前存在的對組資訊
不推薦用第一種方式訪問陣列中的元素:
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();