点击查看Evernote原文

#@author:       gr
#@date: 2014-09-17
#@email: forgerui@gmail.com

Chapter5 算法

Topic 30: 确保目标区间足够大

  如果所使用的算法需要指定一个目标区间,那么必须确保目标区间足够大,或者保证它会随着算法的运行而增大。可以使用back_inserterfront_inerter或者inserter返回的迭代器。

transform(values.begin(), values.end(), back_inserter(results), transmogrify);

Topic 31: 了解各种与排序有关的选择

  根据不同的需求选择不同的排序函数。稳定排序一般比不稳定排序开销更大。

  

  vector,string,deque或者数组执行一次完全排序,可以使用sortstable_sort。如果对前n个元素进行排序,可以使用partial_sort。如果只需找到前n个元素,而不需要对这n个元素进行排序,则使用nth_element

  

  如果将一个标准序列容器中的元素按照是否满足某个特定的条件区分开来,那么partitionstable_partition可能正是你所需要的。

  

  如果数据在一个list中,仍然可以使用partitionstable_partition算法,其它的方法对于list不适应。但可以使用list::sort取代sortstable_sort算法。如果需要partial_sortnth_element的效果,可以通过间接的方法实现。

  

Topic 32: 如果确实需要删除元素,则在remove之后调用erase

  删除容器中一些元素,remove是将相关的元素移到容器的最后,将.end()前移,并没有真正删除元素。需要再次调用erase删除元素。

  

  listremove函数实际上已经默认调用了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, mergeincludes, set_intersection, set_union, set_difference

排序算法一般使用等价来进行排序,uniqueunique_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进行区间统计

  accumulatefor_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的更多相关文章

  1. 《Effective STL》学习笔记

    http://www.cnblogs.com/arthurliu/archive/2011/08/07/2108386.html 作者:咆哮的马甲 出处:http://www.cnblogs.com/ ...

  2. ###《Effective STL》--Chapter3

    点击查看Evernote原文. #@author: gr #@date: 2014-09-13 #@email: forgerui@gmail.com Chapter3 关联容器 Topic 22: ...

  3. ###《Effective STL》--Chapter6

    点击查看Evernote原文. #@author: gr #@date: 2014-09-27 #@email: forgerui@gmail.com Chapter6 函数子.函数子类.函数及其他 ...

  4. ###《Effective STL》--Chapter7

    点击查看Evernote原文. #@author: gr #@date: 2014-08-31 #@email: forgerui@gmail.com Chapter7 在程序中使用STL Topic ...

  5. ###《Effective STL》--Chapter1

    点击查看Evernote原文. #@author: gr #@date: 2014-09-12 #@email: forgerui@gmail.com Chapter1 容器 Topic 4: 调用e ...

  6. ###《Effective STL》--Chapter2

    点击查看Evernote原文. #@author: gr #@date: 2014-09-15 #@email: forgerui@gmail.com Chapter2 vector和string T ...

  7. ###《Effective STL》--Chapter4

    点击查看Evernote原文. #@author: gr #@date: 2014-09-14 #@email: forgerui@gmail.com Chapter4 迭代器 Topic 26: i ...

  8. 容器使用的12条军规——《Effective+STL中文版》试读

    容器使用的12条军规——<Effective+STL中文版>试读     还 记的自己早年在学校学习c++的时候,老师根本就没有讲STL,导致了自己后来跟人说 起会C++的时候总是被鄙视, ...

  9. 《Effective STL中文版》前言

    <Effective STL中文版>前言     我第一次写关于STL(Standard Template Library,标准模板库)的介绍是在1995 年,当时我在More Effec ...

随机推荐

  1. hdoj 4548 美素数

    美素数 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total Submiss ...

  2. Modbus调试利器 Modbus Poll

    Modbus Poll是一个非常不错的工具,支持TCP/串口 下载地址:http://pan.baidu.com/share/link?shareid=2880213929&uk=248325 ...

  3. (莱昂氏unix源代码分析导读-50)LP11行式打印机

    by cszhao1980 LP11有两个设备寄存器:状态寄存器(lpsr)和数据缓冲寄存器(lpbuf),可通过以下结构进行访问: 8812: #define LPADDR 0177514 8823 ...

  4. Python中如何把一个UTC时间转换为本地时间

    需求: 将20141126010101格式UTC时间转换为本地时间. 在网上搜了好长时间都没有找到完美的解决方案.有的引用了第三方库,这就需要在现网安装第三方的软件.这个是万万不可的.因为真实环境不一 ...

  5. 解决SenTestingKit/SenTestingKit.h: No such file or directory

    在一个iOS项目中引入了单元测试,感觉项目间的依赖关系有些乱,就建了一个新的Project,再把原来的.h和.m加进去,编译时竟然出现“SenTestingKit/SenTestingKit.h: N ...

  6. android开发学习:打电话和发短信

    1.新建一个android项目 File--New--Other--android application project 填写application name(就是应用的名字.比方:天天酷跑) 填写 ...

  7. air写文件 SecurityError: fileWriteResource 时报错的解决方法

    用 File.applicationDerectoryPath.resolv("text.txt")会报SecuriyError错误! 解决: var _Path:File = F ...

  8. 详解 Objective-C 中的 Runtime

    公司项目用到一个三方开源库,里面有个bug,不能改动源码,我想来想去,只能通过runtime这个万能的手段来解决.但是runtime 并不怎么会用,怎么办,马上学习呗.说到runtime,它是Obje ...

  9. SQL Server I/O 问题的诊断分

    一. SQL Server 什么时候和磁盘打交道: 1. SQL 需要访问的数据没有在Buffer pool中,第一次访问时需要将数据所在的页面从数据文件中读取到内存中.(只读) 2. 在insert ...

  10. JavaScript总结2--函数

    一.定义函数 在js中,函数也是对象,能赋值给变量,能当作参数,可以设置属性,和调用他拥有的方法.函数的toString()方法,会返回他完整的函数内容.他有两个定义方法,函数表达式和函数声明.当一个 ...