看书的速度终于慢了下来,倒不是难于理解,而是需要理解的东西有点多。

先吐槽下C++Primer这本书,不少地方都是用抽象的语言进行介绍!

拜托,你这是介绍,不是总结!

像容器适配器那里:

“本质上,适配器是使一事物的行为类似于另一事物的行为的一种机制。容器适配器让一种已存在的容器类型采用另一种 不同的抽象类型的工作方式实现。”

直接说转换接口不是更通俗易懂吗???

>>>>>>>>>>>>>>>>>吐槽结束>>>>>>>>>>>>>>>>>>>>>

泛型,generic,这个概念比较抽象。当初学Java的时候对这个词就不知所云,不过看过例子就明白了。--纠结于汉语的博大精深~

C++中的泛型也是类似的概念,虽然还没看到后面的部分。

算法,书中特指的是标准库自带的算法,据说100多种,大多用于操作容器(将IO流也看作某种序列)。

基本上,算法应用于一段范围内的元素上,而算法又独立于容器,所以算法大多是通过一对迭代器来遍历并操作元素。

所以要求迭代器能自增自减、能解引用、能比较、能标识结尾,有的还要求容器的元素类型支持比较等---这与具体的算法有关,就不一一细说了。

注意,多数时候不要求类型匹配,只要元素可以比较即可。

迭代器:容器对象迭代器、io流对象迭代器!--因为io流可以看做一种序列,其迭代器可以自增。

容器对象迭代器的格式如下:

C<T>::iterator iter=c.begin(); // or .end()
C<T>::const_iterator iter=c.begin(); // or .end()
C<T>::reverse_iterator iter=c.rbegin(); // or .rend()

io流对象迭代器的格式如下:

istream_iterator<T> in(istream&); //绑定输入流,如cin等。
istream_iterator<T> eof; //超出末端迭代器!!!用于判断是否结束。
ostream_iterator<T> out(ostream&); //绑定输出流,如cout等。

上面,需要说明的是,如果输入流遇到错误或结束符,则迭代器指向eof

另外,io对象流中的数据需要迭代器不断自增以读取或输出。

关于容器逆向迭代器,就是从尾部rbegin()开始,至头部前面rend()。可以通过vi.base()获取对应的正向迭代器--但是注意了,二者并非指向同一个元素!!!

书中罗列的函数

find(b, e, val); //范围内查找元素,如找到,返回该元素的迭代器,否则返回超出末端迭代器。

find_if(b, e, func); //范围内查找满足函数func的元素,返回第一个满足元素的迭代器或超出末端迭代器。

accumulate(b, e, init_val); //累加范围内的元素,再加上init_val。init_val的意义在于指明类型。务必注意字符串字面值和string的区别,这里不会自动转换!

find_first_of(b1, e1, b2, e2); //从第一个范围内查找第二范围内出现的任意的元素。可用于统计公有元素数量或元素(见例子)

fill(b, e, val); //范围内的元素用val覆盖。

fill_n(iter, count, val); //从iter开始,用val覆盖count长度范围内的元素。--要求iter+count在有效范围内!!!

//迭代器适配器

back_inserter(c); //写入的时候,底层调用push_back

front_inserter(c); //写入的时候,底层调用push_front。所以vector不行。

inserter(c); //写入的时候,底层调用insert。

//迭代器适配器返回包装后的迭代器,方法一样,但操作不同。如:

fill_n(back_inserter(c), count, val); //这样会在尾部追加count个val。

copy(b, e, iter); //将范围内的元素复制到iter后面。

//算法的_copy版本!对输入元素进行处理,但不修改原元素,而是创建一个副本。

replace(b, e, v1, v2); //用v2替换范围内的v1。

replace_copy(b, e, iter, v1, v2); //用v1替换范围内的v2,并保存到iter处。be范围内不变。--需要指定目标迭代器

sort(b, e); //对范围内的元素进行排序

stable_sort(b, e, func); //其实就是懒排序,例如通过长度排序时,只要相邻的元素长度一致,则相对位置不会改变。

unique(b, e); //将范围内的元素去重后 覆盖范围内前面的元素,返回没被覆盖的第一个元素迭代器。

count(b, e, val); //

count_if(b, e, func); //

C++泛型和算法的更多相关文章

  1. c/c++ 通用的(泛型)算法 之 只读算法,写算法,排序算法

    通用的(泛型)算法 之 只读算法,写算法,排序算法 只读算法: 函数名 功能描述 accumulate 求容器里元素的和 equal 比较2个容器里的元素 写算法 函数名 功能描述 fill 用给定值 ...

  2. c/c++ 通用的(泛型)算法 generic algorithm 总览

    通用的(泛型)算法 generic algorithm 总览 特性: 1,标准库的顺序容器定义了很少的操作,比如添加,删除等. 2,问题:其实还有很多操作,比如排序,查找特定的元素,替换或删除一个特定 ...

  3. C++泛型程序设计---算法和提升

    算法和提升 算法:所谓算法就是一个求解问题的过程或公式,即,通过一个有穷的计算序列生成结果. 函数模板就是普通函数的泛化:它能对多种数据类型执行动作,并且能用以参数方式传递来的各种操作实现要执行的工作 ...

  4. C++泛型线性查找算法——find

    C++泛型线性查找算法--find <泛型编程和STL>笔记及思考. 线性查找可能是最为简单的一类查找算法了.他所作用的数据结构为一维线性的空间.这篇文章主要介绍使用 C++ 实现泛型算法 ...

  5. 泛型(Generics)

    Framework类库中的泛型 泛型可以使代码重用,提高开发效率 CLR允许在引用类型.值类型或接口中定义泛型方法: CLR允许创建泛型引用类型.泛型值类型(枚举不允许创建).泛型委托类型和泛型接口类 ...

  6. STL笔记(6)标准库:标准库中的排序算法

    STL笔记(6)标准库:标准库中的排序算法 标准库:标准库中的排序算法The Standard Librarian: Sorting in the Standard Library Matthew A ...

  7. 十一、C# 泛型

    为了促进代码重用,尤其是算法的重用,C#支持一个名为泛型的特性. 泛型与模块类相似. 泛型使算法和模式只需要实现一交.而不必为每个类型都实现一次.在实例化的时候,传入相应的数据类型便可. 注:可空值类 ...

  8. Java Collections API和泛型

    Java Collections API和泛型 数据结构和算法 学会一门编程语言,你可以写出一些可以工作的代码用计算机来解决一些问题,然而想要优雅而高效的解决问题,就要学习数据结构和算法了.当然对数据 ...

  9. <NET CLR via c# 第4版>笔记 第12章 泛型

    泛型优势: 源代码保护 使用泛型算法的开发人员不需要访问算法的源代码.(使用c++模板的泛型技术,算法的源代码必须提供给使用算法的用户) 类型安全 向List<DateTime>实例添加一 ...

随机推荐

  1. 关于centos7中使用rpm方式安装mysql5.7版本后无法使用root登录的问题

    最近在centos7中通过rpm方式安装了最新版本的mysql-server 5.7 (mysql57-community-release-el7-7.noarch.rpm) ,发现安装成功后无法使用 ...

  2. 后缀crt证书转换

    转换地址:https://www.chinassl.net/ssltools/convert-ssl.html 转换成功后点下载即可

  3. 基于Vuejs实现 Skeleton Loading 骨架图

    原文地址:https://cloud.tencent.com/developer/article/1006169 https://mp.weixin.qq.com/s/qmyn6mGrO6hRKuvK ...

  4. windows下配置nginx+php环境(转)

    刚看到nginx这个词,我很好奇它的读法(engine x),我的直译是“引擎x”,一般引“擎代”表了性能,而“x”大多出现是表示“xtras(额外的效果)”,那么整个词的意思就是类似“极致效果”,“ ...

  5. PHP函数register_shutdown_function的使用示例

    某些情况下,我们需要在程序执行结束时,做一些后续的处理工作,这个时候,php的register_shutdown_function函数就可以帮我们来实现这个功能. 函数简介 当PHP程序执行完成后,自 ...

  6. Synplify9.6.2破解(转帖)

    Synplify9.6.2破解(转帖)   转载自:http://www.cnblogs.com/mark-sun/archive/2012/02/26/2368773.html Abstract本文 ...

  7. 【Android】18.2 利用百度定位服务API实现位置跟踪

    分类:C#.Android.VS2015: 创建日期:2016-03-04 一.简介 第3章已经介绍过百度定位SDK,这里再演示一遍其基本用法. 二.示例2-百度定位服务基本用法 运行截图 设计步骤 ...

  8. 黑马day16 jquery案例演示

    案例一: <html> <head> <meta http-equiv="Content-Type" content="text/html; ...

  9. Python 按当前日期(年、月、日)创建多级目录的方法

    先看实际效果,现在时间2018.4.26 使用python脚本按照年月日生成多级目录,创建的目录可以将系统生成的日志文件放入其中,方便查阅,代码如下: #!/usr/bin/env python #c ...

  10. Log4j常用配置及使用

    Log4j常用配置及使用 2016-12-14 目录 1 添加log4j依赖2 使用代码配置并调用log  2.1 代码配置LogConfiguration.java  2.2 调用  2.3 结果3 ...