当前位置:  编程技术>c/c++/嵌入式

C++泛型算法的一些总结

    来源: 互联网  发布时间:2014-10-19

    本文导语:  泛型算法的一些总结1、每个泛型算法的实现都独立于单独的容器,并且不依赖于容器存储的元素类型。 2、泛型算法从不直接添加或删除元素。 3、与容器的类型无关,只在一点上隐式地依赖元素类型:必须能够对元素做比较...

泛型算法的一些总结
1、每个泛型算法的实现都独立于单独的容器,并且不依赖于容器存储的元素类型。

2、泛型算法从不直接添加或删除元素。

3、与容器的类型无关,只在一点上隐式地依赖元素类型:必须能够对元素做比较运算。

A、需要某种遍历集合的方式:能够从一个元素向前移到下一个元素。

B、必须能够知道是否到达了集合的末尾。

C、必须能够对容器中的每一个元素与被查找的元素进行比较。

D、需要一个类型来指示元素在容器中的位置,或者表示找不到该元素。

4、迭代器将算法和容器绑定起来。算法基于迭代器及其操作实现,而并非基于容器操作。

5、使用泛型算法必须包含algorithm头文件

6、通常泛型算法都是在标记容器(或其他序列)内的元素范围的迭代器上操作的,标记范围的两个实参类型必须精确匹配,而迭代器本身必须标记一个范围,第一个迭代器通过不断地处境,必须可以到到达第二个迭代器。

7、String标准库为string对象与char *对象定义了相等(==)操作符。

8、谓词(函数):是做某些检测的函数,返回用于条件判断的类型,指出条件是否成立。函数名可用于函数形参。

9、unique 的使用:该算法删除相邻的重复元素,然后重新排列输入范围内的元素,并且返回一个迭代器,表示无重复的值范围的结束。unique实际上并没有删除任何元素,而是将无重复的元素复制到序列的前端,返回的迭代器指向超出无重复无素范围末端的下一位置。注:由于该算法删除相邻的重复元素,所以在调用此函数之前,要调用sort函数进行排序。

10、关联容器的键是const对象,因此关联容器的迭代器视为支持自减远处的输入迭代器,而不是完整的双向迭代器。

11、泛型算法的结构:

A、通常有一对迭代器标记输入范围。

B、_if 版本的带有一个谓词函数开参,谓词函数用于表示所提供操作的要求,例如排序的规则。

C、_copy 版本多了一个绑定到容器元素类型相同(或可转换)的另一个容器,把一个容器的元素复制到绑定的容器中,并实现算法的操作,但对输入迭代器所标记的容器没有影响。

12、关于list 容器的特有算法。

list 容器上的迭代器是双向的,而不是随机访问类型。由于list 容器不支持随机访问,因此,在此窗口上不能使用使用需要随机访问迭代器的算法sort , 而merge, remove, reverse, unique 等性能也非常低。对于list 对象,应该优先使用list 容器特有的成员版本,而不是泛型算法。

list 特有的算法与其泛型算法版本之间有两个到头重要的差别,list容器特有的操作能添加和删除元素。

A、remove和 unique 的list版本修改了其关联的基础容器,真正地删除了指定的元素。

B、list容器提供的merge和splice运算会破坏它们的实参。使用merge 的泛型算法版本时,合并的序列将写入目标迭代器指向的对象,而它的两个输入序列保持不变。但是,使用list容器的merge成员函数时,则会破坏它的实参list对象,当实参对象的元素合并到调用merge函数的list对象时,实参对象的元素被移出并删除。


    
 
 

您可能感兴趣的文章:

  • c++实现MD5算法代码示例
  • 文本压缩算法C++实现 Golden Huffman
  • 【help】哪里有封装好的RSA算法C++类和C源代码以及例子程序
  • C++实现查找中位数的O(N)算法和Kmin算法
  • 用C或C++编程,模拟可变分区存储管理且首次适应的算法实现存储器的分配与回收
  • C++实现顺序排序算法简单示例代码
  • C++实现汉诺塔算法经典实例
  • C++插入排序算法实例
  • C++选择排序算法实例
  • C++冒泡排序算法实例
  • C++实现N个骰子的点数算法
  • C++归并排序算法实例
  • C++ 冒泡排序数据结构、算法及改进算法
  • C++算法之海量数据处理方法的总结分析
  • C++实现矩阵原地转置算法
  • C++基本算法思想之穷举法
  • 利用C++的基本算法实现十个数排序
  • C++基本算法思想之递推算法思想
  • 采用C++实现区间图着色问题(贪心算法)实例详解
  • C++堆排序算法的实现方法
  • C++实现迷宫算法实例解析
  • 算法之排序算法的算法思想和使用场景总结
  • Oracle中三种表连接算法的总结
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • <<大话数据结构>>中冒泡排序算法改进
  • 那位高人有任务分配问题的禁忌搜索算法、模拟退火算法的算法实现程序啊
  • 二叉树常用算法(求总节点个数和叶子节点个数)
  • 求对称加密DES算法与非对称加密RSA算法!(可用)
  • boost unordered_map和std::list相结合的实现LRU算法
  • 深入串的模式匹配算法(普通算法和KMP算法)的详解
  • 中文网页快速去重算法研究
  • java 合并排序算法、冒泡排序算法、选择排序算法、插入排序算法、快速排序算法的描述
  • 使用java jdk中的LinkedHashMap实现简单的LRU算法
  • 谁能给出一个最快最高效的求素数的算法?(高分求算法)
  • 广告系统中weak-and算法原理及编码验证
  • 谁有这样的算法:给定两个区域,用直线或折线来连接,以及移动其中线段的算法。
  • c语言实现MD5算法完整代码示例
  • 【算法】扑克发牌算法实现
  • MD5算法的C语言实现
  • php加密算法之实现可逆加密算法和解密分享
  • PHP中对各种加密算法、Hash算法的速度测试对比代码
  • 数据库 iis7站长之家
  • 哈希算法计算 Generic Hash and HMAC Program
  • python算法学习之桶排序算法实例(分块排序)
  • 求高效算法


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3