参考:http://www.weixueyuan.net/view/6406.html

总结:

  STL提供了大量操作容器的算法,这些算法大致可以分为:排序、搜索、集合运算、数值处理和拷贝等,这些算法的实现是采用函数模板来实现的,函数模板类似于类模板。

  对于STL算法而言,算法是一样的,只是所处理的容器不同,只要使用合适的迭代器,就可以直接用算法操作容器了。

  如果我们需要使用STL算法,则需要在头文件中包含algorithm头文件,在本程序中使用了四种STL算法:generate、replace_if、sort和for_each。

  sort函数前面两个参数仍然是迭代器,第三个参数是可选的,默认情况下sort将会以升序进行排序。

  STL中还提供了很多其它的算法,在今后的学习过程中,大家如果有需要可以去查找C++的类库手册。

---------------------     

STL提供了大量操作容器的算法,这些算法大致可以分为:排序、搜索、集合运算、数值处理和拷贝等,这些算法的实现是采用函数模板来实现的,函数模板类似于类模板。对于STL算法而言,算法是一样的,只是所处理的容器不同,只要使用合适的迭代器,就可以直接用算法操作容器了。

例1:

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std; bool compare( const int & a, const int & b)
{
return a > b;
} void display( int i )
{
cout<< i << " ";
} bool odd( int i )
{
return i % != ;
} int main()
{
vector < int > num ( );
//生成随机数字,填充num
generate( num.begin(), num.end(), rand );
//将其中的奇数全部替换我0
replace_if( num.begin(), num.end(), odd, );
//从大到小排序
sort( num.begin(), num.end(), compare );
for_each( num.begin(), num.end(), display );
cout << endl;
return ;
}

如果我们需要使用STL算法,则需要在头文件中包含algorithm头文件,在本程序中使用了四种STL算法:generate、replace_if、sort和for_each。下面我们来一一了解这四种算法的功能。

generate函数前面两个参数均为迭代器,分别指向开头和结尾,通过这两个迭代器,我们可以为num的10个元素赋值。由于num是整型的vector实例,因此要求generate函数的第三个参数返回值也为整型,因此我们将库函数rand作为第三个参数,用于生成随机数,其返回值是整型。

调用完generate函数之后,num中就分别填充了一些随机数值。replace_if前面两个参数还是两个迭代器,通过这两个迭代器我们可以对num进行遍历,遍历过程中会逐一判断元素是否为奇数,如果为奇数,则将其换为0。Replace_if要求第三个参数为一个返回bool类型的函数,为此我们专门设计了一个odd函数,用于判断数值是否为奇数,如果为奇数则返回true,否则返回false。因为num为int型vector实例,因此要求用来替换的元素也必须为int型,故replace_if函数最后一个参数必须为int型,在本例中我们直接使用0。

接着我们对num进行排序,sort函数前面两个参数仍然是迭代器,第三个参数是可选的,默认情况下sort将会以升序进行排序。本例中使用了第三个参数,第三个参数为compare函数的函数名。因为num为整型实例,因此compare函数的两个参数为整型的引用。同时由于sort函数要求第三个参数为返回一个bool类型的函数,因此compare也必须返回bool类型。本例中我们希望num以降序的方式排列,因此我们compare函数返回“a > b”。当我们返回“a < b”或者根本就不提供第三个参数时,函数将会以升序的形式排列num。

最后为了打印num中的所有元素,我们使用了for_each函数,当然如果使用循环根据下标或使用迭代器都是可以打印num中的元素的,只不过我们是想介绍一下for_each函数而已。for_each函数前面两个参数仍然是两个迭代器,通过这两个迭代器,我们就可以遍历num中的元素。for_each函数第三个参数用来完成打印操作,我们定义了一个display函数用于完成此操作。

在整个程序中我们一直没有使用任何循环就完成了整个操作,这是因为这四个函数中分别定义了内建的迭代操作,而我们只需要指明迭代的起始和终止位置即可。

STL中还提供了很多其它的算法,在今后的学习过程中,大家如果有需要可以去查找C++的类库手册。

7.9 C++ STL算法的更多相关文章

  1. STL算法

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

  2. 【STL源码学习】STL算法学习之四

    排序算法是STL算法中相当常用的一个类别,包括部分排序和全部排序算法,依据效率和应用场景进行选择. 明细: sort 函数原型: template <class RandomAccessIter ...

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

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

  4. 【STL源码学习】STL算法学习之二

    第一章:前言 学习笔记,记录学习STL算法的一些个人所得,在以后想用的时候可以快速拾起. 第二章:明细 copy 函数原型: template <class InputIterator, cla ...

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

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

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

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

  7. STL源代码分析——STL算法remove删除算法

    前言 因为在前文的<STL算法剖析>中,源代码剖析许多.不方便学习,也不方便以后复习,这里把这些算法进行归类.对他们单独的源代码剖析进行解说.本文介绍的STL算法中的remove删除算法. ...

  8. STL源代码分析——STL算法merge合并算法

    前言 因为在前文的<STL算法剖析>中.源代码剖析许多.不方便学习.也不方便以后复习,这里把这些算法进行归类.对他们单独的源代码剖析进行解说.本文介绍的STL算法中的merge合并算法. ...

  9. STL源代码分析——STL算法sort排序算法

    前言 因为在前文的<STL算法剖析>中,源代码剖析许多,不方便学习,也不方便以后复习.这里把这些算法进行归类,对他们单独的源代码剖析进行解说.本文介绍的STL算法中的sort排序算法,SG ...

  10. 变易算法 - STL算法

    欢迎访问我的新博客:http://www.milkcu.com/blog/ 原文地址:http://www.milkcu.com/blog/archives/mutating-algorithms.h ...

随机推荐

  1. win10安装PS和AI后报代码为16的错误解决方法

    win10安装PS和AI后报代码为16的错误解决方法 一.总结 一句话总结:修改兼容性和以管理员方式运行就可以了 修改兼容性 以管理员身份运行 二.PS和AI安装后报代码为16的错误解决方法介绍(转) ...

  2. springboot外置的Servlet容器

    嵌入式Servlet容器:应用打成可执行的jar ​ 优点:简单.便携: ​ 缺点:默认不支持JSP.优化定制比较复杂(使用定制器[ServerProperties.自定义EmbeddedServle ...

  3. centos 下卸载mysql

    查看当前已安装服务 [root@localhost]# rpm -qa|grep -i mysqlMySQL-server-5.6.36-1.rhel5.x86_64qt-mysql-4.8.5-13 ...

  4. English trip V1 - B 22. Here,There and Everywhere 无处不在 Teacher:Taylor Key: Be + Ving

    In this lesson you will learn to describe what you see. 课上内容(Lesson) # How's the weather today? 今天的天 ...

  5. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: ..... this is incompatible with sql_mode=only_full_group_by

    一.异常信息 org.springframework.jdbc.BadSqlGrammarException: ### Error querying database. Cause: com.mysq ...

  6. ssh登陆报错:packet_write_wait: Connection to x.x.x.x port 22: Broken pipe

    ssh登陆报错:packet_write_wait: Connection to x.x.x.x port 22: Broken pipe 参考文章: https://patrickmn.com/as ...

  7. 网站访问出现 ------ Can not write to cache files, please check directory ./cache/ .

    最近在搞微商城时,突然出现了Can not write to cache files, please check directory ./cache/ .这样一个提示, 但最近好像没搞什么大动作,怎么 ...

  8. 模拟curl函数

    只要需要调用微信的网址,就需要模拟curl请求 $tokenUrl="https://api.weixin.qq.com/cgi-bin/token?grant_type=client_cr ...

  9. hdu6331 Walking Plan

    题意: sol: 考虑floyed 直接暴力做的话复杂度是kn^3会炸. 考虑一个比较神仙的分块做法. 注意到我们是可以直接求单独某个k的矩阵,使用矩阵快速幂即可(取min的矩阵乘法). 单独求一次的 ...

  10. 【洛谷p2142】高精度减法

    高精度减法第一遍没有过 高精度减法[传送门] 洛谷算法标签: 总之技术都在高精上了吧. 附代码: #include<iostream> #include<cstdio> #in ...