网站大量收购独家精品文档,联系QQ:2885784924

c++_unit标准模板库.ppt

  1. 1、本文档共62页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
c++_unit标准模板库.ppt

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 11.5.2 映射和多重映射类 映射和多重映射类引入: 它们提供了操作与关键字相关联的映射值(mapped value)的方法。映射和多重映射的主要差别在于多重映射允许存放与映射值相关联的重复关键字,而映射只允许存放与映射值一一对应的单一关键字。 多重映射和映射关联容器类用于快速存储和读取关键字与相关值(关键字/数值对,key/value pair)。如果保存学生的简明资料,要求按学号排序,使用映射关联容器(因为不会重号)是最合适的。如用姓名排序,因姓名可能重复,使用多重映射更为合适。使用时要用头文件map。 11.5.2 映射和多重映射类 map类模板声明: templatetypename Key,typename T,typename Pred = lessKey, typename A = allocatorpairconst Key,T class map; map容器有多种构造函数: map (); //构造一个空的按默认次序排列的映射 map (pr); //构造一个空的按函数对象pr排序的映射 map (first,last); //构造按默认次序排列的映射, //元素值由区间[first,last)指定的有序序列复制 map (first,last,pr); //同上,但按函数对象pr排序 这些构造函数还可以显式给出分配子(allocator)对象。 11.5.2 映射和多重映射类 映射的使用: 映射和多重映射类支持双向迭代子。 映射定义了成员操作符[]: T operator[const Key key] 这样映射的使用是非常方便的,就如同一个数组,关键字作为下标,相关值作为元素值。 【例11.8】我国部分省份与面积映射关联容器类的演示。 11.6 容器适配器 容器适配器(container adapter): 栈,队列和优先级队。所谓适配器并不独立,它依附在一个顺序容器上。如要声明一个用矢量实现的字符型堆栈,声明如下: stackvectorchar sk; 然后它可以象顺序容器一样使用。但它没有自己的构造和析构函数,它使用其实现类(如vector)的构造和析构函数。队列(queue)默认用deque为基础,栈(stack)可用vector或deque为基础。 11.5.1 栈类 11.5.2 队列类 11.5.3 优先级队列类 11.5.1 栈类 栈并不独立,它依附在一个顺序容器上。栈(stack)可用vector或deque为基础。 声明一个用矢量实现的字符型堆栈,格式如下: stackvectorchar sk; 【例11.9】演示堆栈的压入和弹出。 栈类的引入: 11.5.2 队列类 队列(queue): 默认以deque为基础 【例11.10】演示队列的入队和出队。 11.5.3 优先级队列类 优先级队列(priority_queue)适配器: 用以实现优先级队列。元素插入是自动按优先级顺序插入,使最高优先级元素首先从优先级队列中取出。常用矢量为基础容器。默认时priority_queue用vector为基础数据结构。 【例11.11】 优先级队列类演示,头文件用queue,优先级用数表示,数值越大优先级越高。 第十一章 标准模板库(选读) 课程全部结束 祝同学们有一个好成绩! 表11.1 标准库容器类 标准库容器类 说明 顺序容器 vector(参量) deque(双端队列) list(列表) 从后面快速插入与删除,直接访问任何元素 从前面或后面快速插入与删除,直接访问任何元素 从任何地方快速插入与删除,双链表 关联容器 set(集合) multiset(多重集合) map(映射) multimap(多重映射) 快速查找,不允许重复值 快速查找,允许重复值 一对一映射,基于关键字快速查找,不允许重复值 一对多映射,基于关键字快速查找,允许重复值 容器适配器 stack(栈) queue(队列) priority_queue (优先级队列) 后进先出(LIFO) 先进先出(FIFO) 最高优先级元素总是第一个出列 表11.2 所有标准库容器共有的函数(1) 提供容器默认初始化的构造函数。通常每个容器都有几个不同的构

文档评论(0)

000 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档