map–C++ STL 学习

  Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力。

  说下map内部数据的组织,map内部自建一颗红黑树(一种非严格意义上的平衡二叉树),这颗树具有对数据自动排序的功能,所以在map内部所有的数据都是有序的

map是使用红黑树实现的,访问、查找和删除操作的复杂度都是O(logn)。

template<
class Key, //键
class T, //值
class Compare = std::less<Key>, //
class Allocator = std::allocator<std::pair<const Key, T>
> class map;

(1)map的创建

map共提供了6个构造函数,这块涉及到内存分配器这些东西,略过不表,在下面我们将接触到一些map的构造方法,这里要说下的就是,我们通常用如下方法构造一个map:

Map<int, string> mapStudent;

(2)遍历操作

遍历map无疑就需要使用到迭代器,下面列出了四种map迭代器

iterator begin();   //返回指向起始元素的迭代器
iterator rbegin(); //返回指向末尾元素的迭代器 iterator end(); //返回指向末尾元素的后一个的迭代器
iterator rend(); //返回指向起始元素的前一个的迭代器

(3)插入操作

1.使用[]插入

直接使用[]插入,如果mymap中不存在键值为”abc”元素,那么就执行插入操作。

mymap["abc"] = 1;

2.插入单个元素

//函数原型:
std::pair<iterator,bool> insert( const value_type& value ); //这里的返回值:bool表示插入是否成功、iterator返回插入的位置
//操作示例:
mymap.insert( map<int, string>::value_type(1, "one") );

3.插入多个元素

//函数原型:
template< class InputIt >
void insert( InputIt first, InputIt last );
//操作示例:
map<int, string> tmp = {
{5, "five"},
{6, "six"}
};
mymap.insert( tmp.begin(),tmp.end() );

4. 使用std::initializer_list插入

C++11中新加入的插入数据方式:

//函数原型:
void insert( std::initializer_list<value_type> ilist );
//操作示例:
mymap.insert( { {7, "seven"}, {8, "eight"}, {9, "nine"} } );

(4)删除操作

1. 删除指定位置的元素

//函数原型:
iterator erase( iterator pos );
//具体示例:
std::map<std::string,int>::iterator it = mymap.erase(mymap.begin()); //返回删除元素的下一个元素的迭代器

2. 删除指定范围的元素

//函数原型:
iterator erase( const_iterator first, const_iterator last );
//具体示例:
mymap.erase(mymap.begin(), mymap.end()); //删除所有的元素

3. 依据键值删除元素

//函数原型:
size_type erase( const key_type& key );
//具体示例:
int num = mymap.erase("abc");

PS:方法一和方法二的返回值都是删除元素的下一个元素的迭代器,在C++11之前他们都是没有返回值的。方法三的返回值是删除元素的数目。

(5)max_size(),最大容纳量;size(),当前的元素个数

cout << "map中的最大容量为:" << map1.max_size() << endl;
cout << "map中的元素个数为:" << map1.size() << endl;

(6)empty(),判断map是否为空

cout << "map是否为空:" << map1.empty() << endl;

如果为空,返回1.否则返回0。

(7)swap():交换两个map中的值。

(8)[],at(),取某位置的元素值

// 取map中某位置的元素值
cout << "在1位置的元素值为:" << map1.at(1) << endl;
cout << "在1位置的元素值为:" << map1[1] << endl;

(9)[],at():修改元素

// 修改map中的某个值
map1[2] = 99; map1.at(3) = 88;

(10)clear():清除所有元素

// 清除所有数据
map1.clear();
cout << "map是否为空:" << map1.empty() << endl;

执行以后就是一个空的map,不包含任何元素。

其他方法

size_type count( const Key& key ) const; //返回关键字为key的元素的个数,在map里结果不是0就是1
iterator find( const Key& key ); //返回key所在位置的迭代器,如果没有找到则返回end()

关于map的更详细介绍可以参考文档:http://en.cppreference.com/w/cpp/container/map

map--C++ STL 学习的更多相关文章

  1. STL学习:STL库vector、string、set、map用法

    本文仅介绍了如何使用它们常用的方法. vector 1.可随机访问,可在尾部插入元素:2.内存自动管理:3.头文件#include <vector> 1.创建vector对象 一维: (1 ...

  2. 侯捷STL学习(九)--关联式容器(Rb_tree,set,map)

    layout: post title: 侯捷STL学习(九) date: 2017-07-21 tag: 侯捷STL --- 第十九节 容器rb_tree Red-Black tree是自平衡二叉搜索 ...

  3. 侯捷STL学习(十)--容器hashtable探索(unordered set/map)

    layout: post title: 侯捷STL学习(十) date: 2017-07-23 tag: 侯捷STL --- 第二十三节 容器hashtable探索 hashtable冲突(碰撞)处理 ...

  4. 标准模板库(STL)学习指南之map映射

    转载自CSDN博客:http://blog.csdn.net/bat603/article/details/1456141 Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关 ...

  5. 标准模板库(STL)学习探究之stack

    标准模板库(STL)学习探究之stack queue priority_queue list map/multimap dequeue string

  6. ###STL学习--vector

    点击查看Evernote原文. #@author: gr #@date: 2014-08-11 #@email: forgerui@gmail.com vector的相关问题.<stl学习> ...

  7. ###STL学习--关联容器

    点击查看Evernote原文. #@author: gr #@date: 2014-08-23 #@email: forgerui@gmail.com STL中的关联容器. ###stl学习 |--迭 ...

  8. ###STL学习--迭代器

    点击查看Evernote原文. #@author: gr #@date: 2014-08-23 #@email: forgerui@gmail.com STL中的迭代器. ###stl学习 |--迭代 ...

  9. ###STL学习--函数对象

    点击查看Evernote原文. #@author: gr #@date: 2014-08-13 #@email: forgerui@gmail.com 在stl中,函数对象被大量地使用,用以提高代码的 ...

随机推荐

  1. Services

    *在实际运行中同样的Service的确只能有一个. Services有两种启动形式: Started:其他组件调用startService()方法启动一个Service.一旦启动,Service将一直 ...

  2. GSM模块_GPRS数据传输机制和原理

    通信专业术语 BSS--基站子系统,通过无线接口与移动台直接联系,负责在一定区域内和移动台通信.(GSM) BTS--基站收发台,可以看作一复杂的无线调制器,BSS的主要部分,每个分配有若干信道.(G ...

  3. 使用unity3d开发app

    做过一些项目,参入过一些项目的计划安排.总觉得一些工具用起来很麻烦,要么是要收费,要么很大很重.没有针对小团队的简单易用的任务管理工具,也可能是找了些不能适合自己的习惯. 所有准备开始自己开发一款项目 ...

  4. Spark(五) -- Spark Streaming介绍与基本执行过程

    Spark Streaming作为Spark上的四大子框架之一,肩负着实时流计算的重大责任 而相对于另外一个当下十分流行的实时流计算处理框架Storm,Spark Streaming有何优点?又有何不 ...

  5. hadoop2.2.0伪分布式安装

    修改主机名和IP的映射关系 vi /etc/hosts 192.168.61.134 hadoop 关闭防火墙 #查看防火墙状态 service iptables status #关闭防火墙 serv ...

  6. Scala 将BigDecimal转换为Long

    待转换.asInstanceOf[Number].longValue (Double转为Long也适用)

  7. 远程管理服务 Windows Remote Management (WS-Management)

    Windows Remote Management (WS-Management) Windows 远程管理(WinRM)服务执行 WS-Management 协议来实现远程管理.WS-Managem ...

  8. EJB学习笔记之十(BMT事务和CMT事务)

     1.前言 前两篇博客主要介绍了与事务相关的知识.比如事务的一些特性,以及并发产生的问题.本篇来解说一下EJB中两种处理事务的方式.一种是以生命式方式来管理事务(CMT):还有一种则是在EJB内部使用 ...

  9. puppeteer 相关知识

    page.waitForNavigation: 但我们通过代码执行到页面跳转时,我们需要等待跳转完成再作其他事情.使用page.waitForNavigation会等待跳转完成.(一般作用在点击链接或 ...

  10. Struts Spring Plugin注意点

    Settings The following settings can be customized. See the developer guide. Setting Description Defa ...