#pragma warning(disable:4786)//放到最顶端,屏蔽编译时的C4786警告
#include <iostream>
//以下2个为map操作 需要的,不需要额外添加lib
#include <map>
using namespace std;
//(0)定义相关类型
typedef struct
{
int id;
char name[20] ;
int age;
}T_student;
typedef map<int, T_student *> STUDENT_ID_MAP;
int main( )
{
//(1) 添加
map<int ,string> maplive;
maplive.insert(pair<int,string>(102,"aclive"));
maplive[112]="April";//最简单的添加方法
//这样非常直观,但存在一个性能的问题。插入2时,先在maplive中查找主键为112的项,没发现,
//然后将一个新的对象插入maplive,键是112,值是一个空字符串,插入完成后,将字符串赋为"April";
//该方法会将每个值都赋为缺省值,然后再赋为显示的值,如果元素是类对象,则开销比较大。我们可以用以下方法来避免开销:
maplive.insert(map<int,string>::value_type(321,"hai"));
//(2)查找
//find()函数返回一个迭代器指向键值为key的元素,如果没找到就返回指向map尾部的迭代器。
// 如下,但是,只有当map中有这个键的实例时才对,否则会自动插入一个实例,值为初始化值。
string tmp = maplive[112];
map<int ,string >::iterator l_it;;
l_it=maplive.find(112);
if(l_it==maplive.end())
cout<<"we do not find 112"<<endl;
else cout<<"wo find 112"<<endl;
//(3)删除
l_it=maplive.find(112);
if(l_it==maplive.end())
cout<<"we do not find 112"<<endl;
else maplive.erase(l_it); //delete 112;
/*
iterator erase(iterator it); //通过一个条目对象删除
iterator erase(iterator first, iterator last); //删除一个范围
size_type erase(const Key& key); //通过关键字删除
clear()就相当于 enumMap.erase(enumMap.begin(), enumMap.end()); */
//(4)map中 swap的用法:
//Map中的swap不是一个容器中的元素交换,而是两个容器交换;
map <int, int> m1, m2, m3;
map <int, int>::iterator m1_Iter;
m1.insert ( pair <int, int> ( 1, 10 ) );
m1.insert ( pair <int, int> ( 2, 20 ) );
m1.insert ( pair <int, int> ( 3, 30 ) );
m2.insert ( pair <int, int> ( 10, 100 ) );
m2.insert ( pair <int, int> ( 20, 200 ) );
m3.insert ( pair <int, int> ( 30, 300 ) );
//(5)迭代访问
//通过map对象的方法获取的iterator数据类型是一个std::pair对象,
//包括两个数据 iterator->first 和 iterator->second 分别代表关键字和存储的数据
cout << "The original map m1 is:";
for ( m1_Iter = m1.begin( ); m1_Iter != m1.end( ); m1_Iter++ )
cout << " " << m1_Iter->second;
cout << "." << endl;
m1.swap( m2 );
cout << "After swapping with m2, map m1 is:";
for ( m1_Iter = m1.begin( ); m1_Iter != m1.end( ); m1_Iter++ )
cout << " " << m1_Iter -> second;
cout << "." << endl;
cout << "After swapping with m2, map m2 is:";
for ( m1_Iter = m2.begin( ); m1_Iter != m2.end( ); m1_Iter++ )
cout << " " << m1_Iter -> second;
cout << "." << endl;
//(5)map的sort问题:
//Map中的元素是自动按key升序排序,所以不能对map用sort函数:
/*
map的基本操作函数:
C++ Maps是一种关联式容器,包含“关键字/值”对
begin() 返回指向map头部的迭代器
clear() 删除所有元素
count() 返回指定元素出现的次数
empty() 如果map为空则返回true
end() 返回指向map末尾的迭代器
equal_range() 返回特殊条目的迭代器对
erase() 删除一个元素
find() 查找一个元素
get_allocator() 返回map的配置器
insert() 插入元素
key_comp() 返回比较元素key的函数
lower_bound() 返回键值>=给定元素的第一个位置
max_size() 返回可以容纳的最大元素个数
rbegin() 返回一个指向map尾部的逆向迭代器
rend() 返回一个指向map头部的逆向迭代器
size() 返回map中元素的个数
swap() 交换两个map
upper_bound() 返回键值>给定元素的第一个位置
value_comp() 返回比较元素value的函数
*/
return 1;
}