C++ Primer学习总结 第10章 泛型算法

第10章 泛型算法


1.    find()泛型算法使用示例:

C++ Primer学习总结 第10章 泛型算法_第1张图片

 

2.    只读算法accumulate:对所给范围的元素求和并返回. 注意accumulate的第3个参数决定着它的返回类型. 即如果第3个参数是double,就算迭代器里都是int,最终还是返回double类型的数.

C++ Primer学习总结 第10章 泛型算法_第2张图片

 

3.    只读算法equal:比较前两个迭代器表示范围的所有元素是否与第3个迭代器表示的对应位置的元素都相同,如果相同返回true。两个容器类型可以不同,保存的元素类型也可以不同,只要元素之间可以比较即可.如string类型和const char*类型之间的比较.

C++ Primer学习总结 第10章 泛型算法_第3张图片

 

4.    写容器算法fill:将指定值赋予容器中的元素. 容器不能为空.

C++ Primer学习总结 第10章 泛型算法_第4张图片

 

5.    使用back_inserter(一种插入迭代器)的示例:

C++ Primer学习总结 第10章 泛型算法_第5张图片

 

6.    拷贝算法copy 和 replace. 只有replace_copy不换改变原迭代器所指的容器内的元素值.

 

7.    排序去重算法sort和unique.

注意:unique并不真正删除容器重复元素,它只不过是把重复元素用不重复元素的值覆盖,容器后面的空间依然有效,不过值是多少就不一定了.

 

8.    稳定排序stable_sort 与 定制操作:

C++ Primer学习总结 第10章 泛型算法_第6张图片

 

9.    lambda与find_if的用法:

C++ Primer学习总结 第10章 泛型算法_第7张图片

 

10.  for_earch算法:对迭代器范围内的每个元素调用一元谓词:

C++ Primer学习总结 第10章 泛型算法_第8张图片

 

11.  lambda的特性:

C++ Primer学习总结 第10章 泛型算法_第9张图片

 

12.  bind函数:P354

C++ Primer学习总结 第10章 泛型算法_第10张图片

 

13.  插入迭代器back_inserter, front_inserter, inserter:

对插入迭代器it执行*it ,++it, it++,it--,--it操作没有任何作用.

假设auto it=inserter(vc,vc.begin()+1); 生成了一个插入迭代器,那么通过it=20插入元素的话,永远只插在vc.begin()+1的前面:

 

使用inserter:

 

使用back_inserter:

C++ Primer学习总结 第10章 泛型算法_第11张图片

 

使用front_inserter:

C++ Primer学习总结 第10章 泛型算法_第12张图片

 

14.  反向迭代器 P363

反向迭代器可以用过rbegin()和rend()方法获得,其++,--与普通迭代器的操作含义不同,需要注意. 可以用base()方法将一个反向迭代器转为普通迭代器.

 


你可能感兴趣的:(C++,C++,C++11,Primer,第5版本)