第09章C++最新发展(二)标准模板库(STL)与泛型算法.pptVIP

第09章C++最新发展(二)标准模板库(STL)与泛型算法.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第09章C最新发展(二)标准模板库(STL)与泛型算法

* * * * * 关联式容器内的元素是排序的,插入任何元素,都按相应的排序准则来确定其位置。关联式容器的特点是在查找时具有非常好的性能。 4种容器通常以平衡二叉树方式实现,插入和检索的时间都是 O(logN) * 容器的共同操作 初始化--每个容器都提供了一个默认构造函数,一个拷贝构造函数 以某个数组的元素为初值完成初始化。 以某个容器的元素为初值完成初始化。 容器的共同操作 与大小相关的操作函数 返回迭代器的函数 容器的共同操作 比较操作 3.4 迭代器(Iterator)简述 指针与数组 指针与其它数据结构呢?比如说链表? 存储空间是非连续的。不能通过对指向这种数据结构的指针做累加来遍历。 能不能提供一个行为类似指针的类,来对非数组的数据结构进行遍历呢?这样我们就能够以同样的方式来遍历所有的数据结构(所有容器)。 用指针遍历数组 迭代器(Iterator)简述 迭代器与容器 通过迭代器,我们可以用相同的方式来访问、遍历容器。 每种容器都必须提供自己的迭代器 容器提供一些函数以获得迭代器并以之遍历所有元素。 用迭代器遍历容器 泛型抽象 迭代器(Iterator)简述 迭代器的概念 迭代器是面向对象版本的指针 指针可以指向内存中的一个地址 迭代器可以指向容器中的一个位置 STL的每一个容器类模版中,都定义了一组对应的迭代器类。使用迭代器,算法函数可以访问容器中指定位置的元素,而无需关心元素的具体类型。 迭代器是一个“可遍历STL容器内全部或部分元素”的对象。 一个迭代器指出容器中的一个特定位置。 具有遍历复杂数据结构的能力。 迭代器(Iterator)简述 迭代器的基本操作 迭代器的类型 输入迭代器 可以用来从序列中读取数据 输出迭代器 允许向序列中写入数据 前向迭代器 既是输入迭代器又是输出迭代器,并且可以对序列进行单向的遍历 双向迭代器 与前向迭代器相似,但是在两个方向上都可以对数据遍历 随机访问迭代器 也是双向迭代器,但能够在序列中的任意两个位置之间进行跳转。 用法和指针一样,其实指针就是一种迭代器 read only不能改变iterator所指对象 write only 单向迭代器,iter++ 双向迭代器,iter++、iter-- 所有指针的运算能力,p+n, p-n, p[n], p1-p2, p1p2 标准库迭代器类型 说明 输入 InputIterator 从容器中读取元素。输入迭代器只能一次一个元素地向前移动(即从容器开头到容器末尾)。 要重读必须从头开始。 输出 OutputIterator 向容器写入元素 。 输出迭代器只能一次一个元素地向前移动。 输出迭代器要重写,必须从头开始 正向 ForwardIterator 组合输入迭代器和输出迭代器的功能, 并保留在容器中的位置(作为状态信息), 所以重新读写不必从头开始。 双向 BidirectionalIterator 组合正向迭代器功能与逆向移动功能 (即从容器序列末尾到容器序列开头) 随机访问 RandomAccseeIterator 组合双向迭代器的功能,并能直接访问容器中的任意元素,即可向前或向后调任意个元素。 * 不同迭代器所能进行的操作(功能) 所有迭代器: ++p, p ++ 输入迭代器: * p, p = p1, p == p1 , p!= p1 输出迭代器: * p, p = p1 正向迭代器: 上面全部 双向迭代器: 上面全部,--p, p --, 随机访问迭代器: 上面全部,以及: p+= i, p -= i, p + i: 返回指向 p 后面的第i个元素的迭代器 p - i: 返回指向 p 前面的第i个元素的迭代器 p[i]: p 后面的第i个元素的引用 p p1, p = p1, p p1, p= p1 迭代器示例 3.5 算法(algorithm) STL中提供能在各种容器中通用的算法,比如插入,删除,查找,排序等。大约有70种标准算法。 算法就是一个个函数模板。 算法表现为一系列的函数模板,它们完整定义在STL头文件中。一般这些函数模板都使用迭代器作为它的参数和返回值,因此泛型算法不依赖于具体的容器。 STL中也定义了一些标准的函数对象,如果以功能划分,可以分为算术运算、关系运算、逻辑运算三大类。为了调用这些标准函数对象,需要包含头文件functional。 泛型算法分类为 (1)不修改序列的操作 find( )、cout( )、equal( )、mismatch( )和search( )等。 (2)修改序列的操作 swap( )、copy( )、transform( )、replace( )、remove( )、 reverse( )、rota

文档评论(0)

haocen + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档