C++泛型和算法
Posted LarryZeal
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C++泛型和算法相关的知识,希望对你有一定的参考价值。
看书的速度终于慢了下来,倒不是难于理解,而是需要理解的东西有点多。
先吐槽下C++Primer这本书,不少地方都是用抽象的语言进行介绍!
拜托,你这是介绍,不是总结!
像容器适配器那里:
“本质上,适配器是使一事物的行为类似于另一事物的行为的一种机制。容器适配器让一种已存在的容器类型采用另一种 不同的抽象类型的工作方式实现。”
直接说转换接口不是更通俗易懂吗???
>>>>>>>>>>>>>>>>>吐槽结束>>>>>>>>>>>>>>>>>>>>>
泛型,generic,这个概念比较抽象。当初学Java的时候对这个词就不知所云,不过看过例子就明白了。--纠结于汉语的博大精深~
C++中的泛型也是类似的概念,虽然还没看到后面的部分。
算法,书中特指的是标准库自带的算法,据说100多种,大多用于操作容器(将IO流也看作某种序列)。
基本上,算法应用于一段范围内的元素上,而算法又独立于容器,所以算法大多是通过一对迭代器来遍历并操作元素。
所以要求迭代器能自增自减、能解引用、能比较、能标识结尾,有的还要求容器的元素类型支持比较等---这与具体的算法有关,就不一一细说了。
注意,多数时候不要求类型匹配,只要元素可以比较即可。
书中罗列的函数
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++泛型和算法的主要内容,如果未能解决你的问题,请参考以下文章