C++ MAP 操作实例

#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;
}

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值