1. 程式人生 > 其它 >map容器的插入和刪除

map容器的插入和刪除

技術標籤: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;

訪問容器裡面元素的兩種方式:
區別:

  1. 第一種方式訪問,如果key0的值不存在,而key1的值存在,在輸出的時候會自動建立一個新的對組,key為0,value值預設為0
  2. 第二種方式訪問,只會輸出當前存在的對組資訊
    不推薦用第一種方式訪問陣列中的元素:
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();