###《Effective STL》--Chapter5
点击查看Evernote原文。
#@author: gr
#@date: 2014-09-17
#@email: forgerui@gmail.com
Chapter5 算法
Topic 30: 确保目标区间足够大
如果所使用的算法需要指定一个目标区间,那么必须确保目标区间足够大,或者保证它会随着算法的运行而增大。可以使用back_inserter,front_inerter或者inserter返回的迭代器。
transform(values.begin(), values.end(), back_inserter(results), transmogrify);
Topic 31: 了解各种与排序有关的选择
根据不同的需求选择不同的排序函数。稳定排序一般比不稳定排序开销更大。
vector,string,deque或者数组执行一次完全排序,可以使用sort和stable_sort。如果对前n个元素进行排序,可以使用partial_sort。如果只需找到前n个元素,而不需要对这n个元素进行排序,则使用nth_element。
如果将一个标准序列容器中的元素按照是否满足某个特定的条件区分开来,那么partition和stable_partition可能正是你所需要的。
如果数据在一个list中,仍然可以使用partition和stable_partition算法,其它的方法对于list不适应。但可以使用list::sort取代sort和stable_sort算法。如果需要partial_sort和nth_element的效果,可以通过间接的方法实现。
Topic 32: 如果确实需要删除元素,则在remove之后调用erase
删除容器中一些元素,remove是将相关的元素移到容器的最后,将.end()前移,并没有真正删除元素。需要再次调用erase删除元素。
list的remove函数实际上已经默认调用了erase了,所以不需要再次调用。
map没有提供remove函数,使用erase删除。
Topic 33: 对包含指针的容器使用remove函数时要特别小心
使用remove时,指针会指向其他地方,这样有些内存就会无法访问,而造成内存泄漏。
方法一是在使用erase-remove之前,将要删除的元素的指针删除并置为空,然后再用erase-remove清除容器中所有的空指针。
方法二是使用智能指针shared_ptr,让系统进行管理。
Topic 34: 了解哪些算法要求使用排序的区间作为参数
需要排序区间的STL算法:
binary_search, lower_bound, upper_bound, equal_range, merge, includes, set_intersection, set_union, set_difference。
排序算法一般使用等价来进行排序,unique和unique_copy使用相等来判断两个对象是否相同。
Topic 36: 理解copy_if算法的正确实现
STL中没有提供copy_if的实现,需要自己实现。它的调用形式应该是下面这样的:
//判断Widget是否有损坏
bool isDefective(const Widget& w);
//调用copy_if形式
copy_if(c.begin(), c.end(), ostream_iterator<Widget>(cerr, "\n"), isDefective);
//copy_if的实现
OutputIterator copy_if(InputIterator begin, InputIterator end, OutputIterator destBegin, Predicate p){
while(begin != end){
if (p(*begin))
*destBegin++ = *begin;
++begin;
}
return destBegin;
}
Topic 37: 使用accumulate或者for_each进行区间统计
accumulate和for_each都可以进行区间统计。可以传递一个函数对象,对每个元素都调用这个函数对象,实现区间统计。实际上从命令上也可以看出,accumulate更偏重于区间统计,而for_each是对每区间的每一个元素做一个操作,当然也可以用来统计信息。
此外,accumulate可以直接返回统计结果,而for_each返回的是一个对象,需要从这个对象中提取统计信息,即在函数中加入一个成员函数,以获得想要的统计信息。
// 容器迭代器调用
accumulate(v.begin(), v.end(), 0.0);
accumulate(istream_iterator<int>(cin), istream_iterator<int>(), 0.0);
// 调用函数
accumulate(ss.begin(), ss.end(), 0, stringLengthSum);
// PointAveraget是一个函数子类,包含operator=(const Point&)和result()成员函数
for_each(lp.begin(), lp.end(), PointAverage()).result();
###《Effective STL》--Chapter5的更多相关文章
- 《Effective STL》学习笔记
http://www.cnblogs.com/arthurliu/archive/2011/08/07/2108386.html 作者:咆哮的马甲 出处:http://www.cnblogs.com/ ...
- ###《Effective STL》--Chapter3
点击查看Evernote原文. #@author: gr #@date: 2014-09-13 #@email: forgerui@gmail.com Chapter3 关联容器 Topic 22: ...
- ###《Effective STL》--Chapter6
点击查看Evernote原文. #@author: gr #@date: 2014-09-27 #@email: forgerui@gmail.com Chapter6 函数子.函数子类.函数及其他 ...
- ###《Effective STL》--Chapter7
点击查看Evernote原文. #@author: gr #@date: 2014-08-31 #@email: forgerui@gmail.com Chapter7 在程序中使用STL Topic ...
- ###《Effective STL》--Chapter1
点击查看Evernote原文. #@author: gr #@date: 2014-09-12 #@email: forgerui@gmail.com Chapter1 容器 Topic 4: 调用e ...
- ###《Effective STL》--Chapter2
点击查看Evernote原文. #@author: gr #@date: 2014-09-15 #@email: forgerui@gmail.com Chapter2 vector和string T ...
- ###《Effective STL》--Chapter4
点击查看Evernote原文. #@author: gr #@date: 2014-09-14 #@email: forgerui@gmail.com Chapter4 迭代器 Topic 26: i ...
- 容器使用的12条军规——《Effective+STL中文版》试读
容器使用的12条军规——<Effective+STL中文版>试读 还 记的自己早年在学校学习c++的时候,老师根本就没有讲STL,导致了自己后来跟人说 起会C++的时候总是被鄙视, ...
- 《Effective STL中文版》前言
<Effective STL中文版>前言 我第一次写关于STL(Standard Template Library,标准模板库)的介绍是在1995 年,当时我在More Effec ...
随机推荐
- linux中ctime,mtime,atime的区别
st_atime Time when file data was last accessed. Changed by the following functions: ...
- 低级错误之Hbm中类型不一致错误
Myeclipse将数据库中的长整形生成为Bigdecimal类型,实际应该生成为Long.导致保存的时候报错.
- 1098. Insertion or Heap Sort (25)
According to Wikipedia: Insertion sort iterates, consuming one input element each repetition, and gr ...
- 剑指OFFER之丑数(九度OJ1214)
题目描述: 把只包含因子2.3和5的数称作丑数(Ugly Number).例如6.8都是丑数,但14不是,因为它包含因子7.习惯上我们把1当做是第一个丑数.求按从小到大的顺序的第N个丑数. 输入: 输 ...
- mac os升级为 Yosemite 10.10 后不能创建javaproject
出现这样的情况可能是因为mac系统升级导致JAVA的安装路径发生改变(Xcode升级后也出现模拟器位置改变的情况,不要奇怪) 之前安装的eclipse就自然找不到SDK的路径了,所以会捆绑失败 接下来 ...
- Custom-Progress-Dialog-Android
https://github.com/ManolescuSebastian/Custom-Progress-Dialog-Android
- poj 1904 King's Quest tarjan求二分图的所有可选最大匹配边
因为是完美匹配,所以每个点都已经匹配了,那么如果要选择一条别的边,增光路的最后必定找到原来所匹配的点,加上匹配的边,那么就是一个环.所以可选边在一个强连通分量里. #include <iostr ...
- [置顶] Java编程笔试题之一 ----文件操作
题目:给定一个文件和一个字符串,判断文件是否包含该字符串,如果包含,请打印出包含该字符串的行号以及该行的全部内容. 思路: ①使用缓冲流(BufferedReader)读取文件,定义初始行号为0. ...
- 基于新浪sae使用php生成图片发布图文微博
1.生成图片的代码: <?php header ("Content-type: image/png"); mb_internal_encoding("UTF-8&q ...
- ajax调用webService中的方法
页面代码 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Index.aspx. ...