条款30:确保目标区间足够大
条款31:了解各种与排序有关的选择
//使用unaryPred划分输入序列,使得unaryPred为真的元素放在序列开头
partition(beg, end, unaryPred);
//对[beg, mid)个元素进行排序,排序后[beg, end)范围元素有序,且为全排序之后的最终位置
partial_sort(beg, mid, end, comp);
//排序后score前3个元素有序且为整个序列的前3名
eg: partial_sort(score.begin(), score.begin() + , score.end());
nth_element(beg, nth, end, comp);    //实参nth必须是一个迭代器,定位输入序列中的一个元素
//执行完之后,位置nth上元素为全排序之后应该放置的元素,且nth之前的元素(不一定有序)都 <= nth所表示值,nth之后的元素(不一定有序)都 >= nth所表示值
nth_element(score.begin(), score.begin() + score.size() / , score.end());

partial_sort、nth_element、sort都是非稳定的排序算法,都要求随机访问迭代器(所以只能应用于 vector、string、deque、array)

总结:
()如果需要对vector、string、deque、array所有元素执行完全排序,可以使用sort或者stable_sort
()如果只需要对vector、string、deque、array最前面的n个元素进行排序,可以使用 partial_sort
()如果vector、string、deque、array 需要找到排序后第n个位置上的元素,或者只需要找到最前面的n个元素(这些元素不是有序),可以使用nth_element
()如果是list容器,可以使用list::sort(成员函数,稳定排序),但是没有partial_sort和nth_element
条款32:如果确实需要删除元素,则需要在 remove 这一类算法之后调用 erase

remove 移动了区间中的元素,结果是:"不用被删除"的元素移到了区间的前面(保持原有的相对顺序),返回一个迭代器指向最后一个"不用被删除"的下一个元素
如果真想删除元素,那就必须在remove之后使用erase
vec.erase(remove(vec.begin(), vec.end(), 2012), vec.end());
remove_if 和 unique 的用法与remove完全相同,都必须结合 erase 完成真正的操作

条款33:对包含指针的容器使用 remove 这一类算法时要特别小心

对包含指针的容器使用 remove-erase 会造成内存泄露,可使用 shared_ptr 代替

条款34:  了解哪些算法要求使用排序的区间作为参数

以下算法必须使用排序区间作为参数:
O(log n)的二分搜索相关算法: binary_search, lower_bound, upper_bound, equal_range
O(n)的集合操作: set_union, set_intersection, set_difference, set_symmetric_difference

条款35:通过 mismatch 实现简单的忽略大小写的字符串比较
条款36:了解 copy_if的实现
条款37:使用 accumulate或者for_each进行区间统计

accumulate使用第三个参数的类型推导出最后计算结果的类型,所以以下两个计算结果完全不同:

double sum = accumulate(vec.begin(), vec.end(), 0.0); //计算结果类型为double
double sum = accumulate(vec.begin(), vec.end(), );//计算结果为int变量,最后转为double型

计算连乘积:

vector<double> vec;
double product = accumulate(vec.begin(), vec.end(), 1.0, multiplies<double>()); //multiplies为仿函数; 注意连乘初始值为1.0

STL学习笔记(五) 算法的更多相关文章

  1. STL学习笔记--排序算法

    排序算法 C++ STL 的排序算法(Sorting algorithms)是一组将无序序列排列成有序序列的模板函数或与排序相关的模板函数,提供了排序.折半搜索.归并.集合操作.堆操作.最值求解.字典 ...

  2. STL学习笔记(算法概述)

    算法头文件 要运用C++标准程序库的算法,首先必须包含头文件<algorithm> 使用STL算法时,经常需要用到仿函数以及函数配接器.它们定义域<functional>头文件 ...

  3. Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据

    Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据 */--> div.org-src-container { font-size: 85%; font-fam ...

  4. Effective STL 学习笔记 31:排序算法

    Effective STL 学习笔记 31:排序算法 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...

  5. Effective STL 学习笔记 39 ~ 41

    Effective STL 学习笔记 39 ~ 41 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...

  6. Effective STL 学习笔记 Item 38 : Design functor classes for pass-by-value

    Effective STL 学习笔记 Item 38 : Design functor classes for pass-by-value */--> div.org-src-container ...

  7. Effective STL 学习笔记 Item 30: 保证目标区间足够大

    Effective STL 学习笔记 Item 30: 保证目标区间足够大 */--> div.org-src-container { font-size: 85%; font-family: ...

  8. Effective STL 学习笔记: Item 22 ~ 24

    Effective STL 学习笔记: Item 22 ~ 24 */--> div.org-src-container { font-size: 85%; font-family: monos ...

  9. Effective STL 学习笔记 Item 21:Comparison Function 相关

    Effective STL 学习笔记 Item 21:Comparison Function 相关 */--> div.org-src-container { font-size: 85%; f ...

随机推荐

  1. 删除.cpp文件

    今天启动vc6.0后随手直接建了一个.cpp文件(没有建什么工程的),编译运行成功后,就把vc关了.后想把这个随手建的文件给删掉,却怎么也找不到这个文件,文件搜索或改变文件的属性也无法找到这个文件,即 ...

  2. URAL 1776 Anniversary Firework (概率,区间DP)

    坑,一开始以为,分成两半的时候去最大那个就行了, 实际上这样是不对的,因为有可能出现小的一半的时间比大的要长, 因为还和等待次数有关,且转移的时候需要用到次数更小的状态, 所以状态定义为二维,dp[i ...

  3. 自己太水了—HDOJ_2212

    Problem Description A DFS(digital factorial sum) number is found by summing the factorial of every d ...

  4. jni ndk 入门

    1. Linux环境模拟,下载sygwin 安装,选择devl 和shell -> install sygwin 中的配置ndk环境,进入安装目录c:/cygwin64 etc/profile文 ...

  5. CAD交互绘制块引用对象(网页版)

    主要用到函数说明: _DMxDrawX::DrawBlockReference 绘制块引用对象.详细说明如下: 参数 说明 DOUBLE dPosX 插入点的X坐标 DOUBLE dPosY 插入点的 ...

  6. UEditor中多图上传的bug

    多图上传 预览:支持浏览器版本  IE8以上 在线管理:由于存在bug,显示不了 ueditor-1.1.1.jar解压后找到FileManager 1.修改com.baidu.ueditor.hun ...

  7. javase(13)_网络编程

    一.概述 1.网络编程的核心是IP.端口(表示应用程序).协议三大元素 2.网络编程的本质是进程间通信 3.网络编程的2个主要问题:1是定位主机,2是数据传输 二.网络通信的概念 1.网络通信协议 计 ...

  8. 玩转ApplicationContextAware

    当一个类实现了这个接口之后,这个类就可以方便地获得 ApplicationContext 中的所有bean.换句话说,就是这个类可以直接获取Spring配置文件中,所有有引用到的bean对象.结合工厂 ...

  9. 【mysql】linux, mac mysql数据库root 密码忘记修改

    首先关闭正在运行的mysqld进程 执行mysqld_safe --skips-grant-tables & 双击enter 键进入命令行模式 执行 mysql linux 系统执行:upda ...

  10. python--第一类对象,函数名,变量名

    一 . 第一类对象 函数对象可以像变量一样进行赋值 , 还可以作为列表的元素进行使用 可以作为返回值返回 , 可以作为参数进行传递 def func(): def people(): print('金 ...