STL算法主要是我们强大的标准库中以迭代器或数值或函数对象为参数预先定义好的一系列算法操作。

在STL算法分类中首先要提的就是两个普遍存在的后缀:

_if

_copy

其中这两个后缀的作用分别是:一、对于_if,如果算法存在两种形式,参数的个数相同,其中一种形式的参数要求传递一个值,而另一种形式则会要求传递一个函数或仿函数(函数对象),那么则没有_if后缀的形式要求传递数值,有_if后缀的则要求传递函数。而且传递的函数一般都会是一个一元或二元的判别式。二、_copy后缀则表示在此算法中元素在被复制到目标区间的同时会被处理,而源序列则保持不变。

除此之外,STL算法可以按照其操作的特性分为一下几个类别:

一、非变动性算法

非变动性算法主要是指不会改变元素的次序和改变元素值的操作,典型的操作是:计数count、求最值(min_element,max_element)、搜寻某个特定元素find、搜寻某段特定元素search_n、搜寻某个子区间(search,find_end)、搜寻第一对连续相等的元素adjacent_find、其次剩余的就是匹配和比较算法了:判断两个连续的区间是否相等equal、在两个序列中返回第一对不想等的元素

二、变动性算法

变动性算法指的是要么直接改变元素值,或者在复制到目标区间的过程中改变元素值且原区间不发生改变。首先要记的是两个特殊的算法:复制和合并:copy从第一个元素开始复制到目标区间、merge合并两个区间;其次就是遍历操作每一个元素for_each、遍历+操作+复制transform(遍历操作复制后原区间不会变,操作的结果覆盖到目标区间,注意既可以对一个原区间间进行一元操作,也可以同时对两个原区间进行二元操作后将结果覆盖到目标区间)、最后就是替换操作:可以批量替换区间的每一个元素:fill以给定值替换区间的所有元素、generate以某项操作的结果替换区间所有元素;替换区间中N个元素:fill_n以给定值替换区间的前N个元素、generate_n以某项操作的结果替换区间的前N个元素,以另一个元素替换某个特定元素replace。

三、移除性算法

移除性算法可以移除某区间内的特定元素也可以在复制到目标区间的过程中去执行移除动作。

不过需要特别注意的是:除了在复制的过程中移除外,其他的移除事实上都只是在逻辑上移除元素,具体的手段是:将不需要被移除的元素往前移覆盖应该被移除的元素,因此这些操作并不改变操作区间内的元素个数,而是返回逻辑上的新终点位置。

移除性算法中最重要就两个操作:一是移除某些特定的元素(包括移除和复制移除);remove移除特定值的元素、remove_if移除满足条件元素、remove_copy复制移除特定元素、remove_copy_if复制移除满足特定条件的元素。二是移除相邻的重复元素:unique移除相邻的重复元素、unique_copy复制并移除相邻的重复元素。注意如果想通过unique算法移除掉序列里的所有重复元素则必须先对序列排序,使其成员有序序列后则用unique移除相邻重复的元素后才能使该序列不包含重复的元素。

四、变序性算法

变序性算法指的是改变序列中元素的顺序但不改变元素的值。

变序算法中最主要的几个操作是:逆转、旋转、分步排序、随机乱序,部分前移

逆序算法:reverse将元素次序逆转、reverse_copy复制的同时逆转元素顺序;旋转元素次序:rotate按参数旋转元素顺序、rotate_copy复制的同时旋转元素次序;分步排序:next_permutation得出朝向降序的下一步变换序列、prev_permutation得出朝着升序的下一步变换序列;随机乱序:random_shuffle将元素次序随机打乱。部分前移算法:partition使满足特定条件的元素移到序列的前面、stable_partition与partition一样也是使满足特定条件的元素移到序列的前面,但是stable_partition保存满足条件和不满足条件的各个元素间的原有相对位置不变。

五、排序算法

排序算法主要是指使序列的全部元素或部分元素或特定位置成为有序的,这与变序算法不同,排序算法中的有序是指排列成升序或降序而变序算法中的有序不一定如此。

排序算法中主要包括的是;对所有位置排序、对部分位置排序、对单个特定位置排序。

对所有位置排序:sort对序列中的所有元素进行排序、stable_sort对所有元素进行排序但是保持相等的元素间的原有相对次序。对部分位置排序:partial_sort对所有元素排序,直到前n个元素就位、partial_sort_copy以目标区间的大小为准对原区间进行复制并排序直到保持相对应的前部分位置有序位置。对单个特定位置进行排序:nth_element对所有元素排序使第n个位置的相应元素就位,并且使位于位置n之前的元素都小于它,位于位置n之后的元素都大于它。

六、对已序区间的算法

对依已序区间的算法主要是值根据原区间元素已序的特定采用特定的算法进行相应的操作,使得这些操作一般通用的操作具有更高的效率,但必备的前提都是该用于操作的原区间必须都是已序序列。

已序算法中主要包括:搜寻、区间合并、集合并集、交集、差集、并集-交集。

搜寻算法:binary_search用二分法搜寻是否包括特定元素、includes搜寻一个区间是否包含另一个区间的全部元素、lower_bound搜寻第一个大于等于给定值的元素、upper_bound搜寻第一个大于给定值的元素、equal_range搜寻等于给定值的区间范围返回数值对。区间合并:merge将两个区间的元素合并、inplace_merge将两个连续的已序区间合并成一个有序区间。并集:set_union求两个区间的并集。交集:set_intersection求两个区间的交集。差集:set_difference求第一个区间与第二个区间的差集。并集-交集:set_symmetric_difference求只出现在两个区间之一的元素并形成一个已序区间。

七、数值运算

数值运算算法指的是以不同的方式组合数值元素。

数值算法中的主要算法包括:accumulate组合一个区间所有元素,以传进初始值参数为准可以进行迭加运算,也可以传进特定的操作函数后,以初始值参数进行迭代运算。inner_product组合两个区间的所有元素,可以是两个区间的对于位置的元素的乘积与初始值参数迭加,也可以传入两个特定参数两个区间的相应位置的元素进行二元操作后在迭代。adjacent_difference将每个元素和其前的一个元素进行组合,每一个元素都与其前面的一个元素相减后进行特定二元操作后将结果另写入一个目标序列。partial_sum将每个元素和其先前的所有元素组合,可以是每一个元素与其所有先前的元素累计或累积进行特定操作后将结果保存写入目标区间。

http://blog.csdn.net/yyc1023/article/details/38558955

STL算法分类记忆的更多相关文章

  1. C++ 之高效使用STL ( STL 算法分类)

    http://blog.csdn.net/zhoukuo1981/article/details/3452118

  2. 从零开始学C++之STL(四):算法简介、7种算法分类

    一.算法 算法是以函数模板的形式实现的.常用的算法涉及到比较.交换.查找.搜索.复制.修改.移除.反转.排序.合并等等. 算法并非容器类型的成员函数,而是一些全局函数,要与迭代器一起搭配使用. 算法的 ...

  3. [Machine Learning] 机器学习常见算法分类汇总

    声明:本篇博文根据http://www.ctocio.com/hotnews/15919.html整理,原作者张萌,尊重原创. 机器学习无疑是当前数据分析领域的一个热点内容.很多人在平时的工作中都或多 ...

  4. paper 12:机器学习常见算法分类汇总

    机器学习无疑是当前数据分析领域的一个热点内容.很多人在平时的工作中都或多或少会用到机器学习的算法.这里南君先生为您总结一下常见的机器学习算法,以供您在工作和学习中参考. 机器学习的算法很多.很多时候困 ...

  5. STL算法

    STL算法部分主要由头文 件<algorithm>,<numeric>,<functional>组成.要使用 STL中的算法函数必须包含头文件<algorit ...

  6. 【STL源码学习】STL算法学习之三

    第一章:前言 数量不多,用到的时候会很爽. 第二章:明细 STL算法中的又一个分类:分割:将已有元素按照既定规则分割成两部分.  is_partitioned 函数原型: template <c ...

  7. 【转】三十分钟学会STL算法

    转载自: http://net.pku.edu.cn/~yhf/UsingSTL.htm 这是本小人书.原名是<using stl>,不知道是谁写的.不过我倒觉得很有趣,所以化了两个晚上把 ...

  8. random_shuffle (stl算法)打乱顺序 - 飞不会的日志 - 网易博客

    random_shuffle (stl算法)打乱顺序 - 飞不会的日志 - 网易博客 random_shuffle (stl算法)打乱顺序 2012-03-31 10:39:11|  分类: 算法 | ...

  9. C++STL 算法

    算法部分主要由头文件<algorithm>,<numeric>和<functional>组成. <algorithm>是所有STL头文件中最大的一个,其 ...

随机推荐

  1. VUE安装步骤1

    文件结构 用官方的 vue-cli 生成的项目文件结构如上图所示,简单介绍下上面图中各文件的作用. src 文件夹 : 1. assets 文件夹:存放各种资源文件,如图片等 2. component ...

  2. Python与C相互调用、编译

    因为最近学习Boost::python的缘故,想尝试下不同语言之间的相互编译. 参考资料:http://blog.csdn.net/joliny/article/details/2457197. 很吃 ...

  3. es6之 async await 使用小计

    var sleep = (time)=>{ return new Promise((resolve,reject)=>{ setTimeout(()=>{ resolve('ok') ...

  4. Android下so注入和hook

    一.前言 总结一下这两天学习的Android注入so文件,通过遍历got表hook函数调用 1.注入so文件 2.so文件中遍历got表hook函数 二.注入so文件 1)注入进程 1.编程思路分为以 ...

  5. Mac OS X安装OpenGL

    Mac OS X安装OpenGL 安装最新的cmake brew install cmake brew upgrade cmake 安装glew brew install glew 安装GLTools ...

  6. SIMD

    SIMD 概述 数据类型 静态方法:数学运算 静态方法:通道处理 静态方法:比较运算 静态方法:位运算 静态方法:数据类型转换 实例方法 实例:求平均值 概述 SIMD(发音/sim-dee/)是“S ...

  7. 次讲解js中的回收机制是怎么一回事。

    在前几天的一篇闭包文章中我们简单的介绍了一下闭包,但是并没有深入的讲解,因为闭包涉及的知识点比较多,为了能够更好的理解闭包,今天讲解一下关于js中的回收机制. 在初识闭包一文中我说过js中有回收机制这 ...

  8. entity framework 查看自动生成的sql

    public MesDbContext() : base("name=mysql") { Database.Log = new Action<string>(msg = ...

  9. Android中BitmapFactory.Options详解

    在Android中,BitmapFactory相信大家都很熟悉了,这个类里面的所有方法都是用来解码创建一个Bitmap,其中有一个重要的类是Options,此类用于解码Bitmap时的各种参数控制,那 ...

  10. Maven运行时找不到xml文件和properties文件的问题解决

    使用Maven构建的项目,包下面的xml文件和properties属性文件默认在运行tomcat插件是不会生成文件到target里面的,需要自己配置 一.第一种解决方法也是最常用的解决方法 在pom. ...