算法的形式
-容器container 是个class template
-算法algorithm 是个function template
算法是要来处理容器中的data,但是算法看不到容器只能通过迭代器获取参数
算法向迭代器索取data,迭代器从容器中取得data提供给算法
算法在处理data时会需要知道data容器的形式,这由迭代器告诉算法
算法发出提问迭代器无法回答的时候编译失败
data:image/s3,"s3://crabby-images/b1f91/b1f91286bcf29c000fd9815ee1c51aef19f2be3d" alt=""
迭代器的分类 (category)
迭代器是要由容器来提供的,根据容器中数据移动特性不同而不同
五种结构为五种不同类型的迭代器,可以被封装成对象
data:image/s3,"s3://crabby-images/b7869/b7869c9a6b42e974049b6367b10a3df25ff8e653" alt=""
data:image/s3,"s3://crabby-images/39b47/39b478cfcc3239d0a6da7b1e1f4fa7f38cbebea4" alt=""
编译过后,编译器会在变量名前后加上其他附加字符作为变量标号
data:image/s3,"s3://crabby-images/ef811/ef811879e5dfb8aee94b3e99a05081223592194c" alt=""
不同标准库版本的做法并不相同,但是接口必须一致
data:image/s3,"s3://crabby-images/7b64e/7b64e7abf8c231ad375bc053e9e000ed29687e16" alt=""
在有些继承关系中的父类只做了一些类型的定义,没有data和function,这时候子类可以继承父类的各种类型
data:image/s3,"s3://crabby-images/ebf50/ebf501a9bf1d0ac21e22303c450cad8e60d788a7" alt=""
迭代器分类 (category) 对算法的影响
distance算法接受两个参数,计算两个指针参数之间的距离
算法的精细可以大大提高操作的效率
在算法中对不同迭代器进行分类操作,对不同的结构进行不同的操作可以提高运行速度
而标准库中的算法已经很精细地写出了各种分类的操作
对标准库的信任和使用非常重要
算法对迭代器没有强制要求,只有暗示,建议使用会使效率更高的迭代器
data:image/s3,"s3://crabby-images/a063d/a063dec524c2bb61c117ec74e310554a6c42db88" alt=""
data:image/s3,"s3://crabby-images/5d409/5d409820201a379d1e7562a0ae375037011fe678" alt=""
data:image/s3,"s3://crabby-images/f53aa/f53aad0d4a1b4e3bbf6c747a17879b7b1aabae03" alt=""
data:image/s3,"s3://crabby-images/712d8/712d8b811a06681b84bd2625a928b0c912883190" alt=""
data:image/s3,"s3://crabby-images/204dc/204dc0e4ea41e63c861a5d54876449114f33dcc4" alt=""
算法源代码剖析 (11个例子)
c算法和c++算法的区别,是否以函数模板形式写出来的
data:image/s3,"s3://crabby-images/8b0d9/8b0d9defcd6f0667cdc18bf4ef034e5f17ad64c3" alt=""
accumulate累计算法
有两个版本
-每次将数值累加
-每次将元素做第三个参数所给出的累次操作,一般情况第三个参数所给的是一个可被调用的可以函数也可以是仿函数
data:image/s3,"s3://crabby-images/7f9db/7f9db741e6da2f4f73201bb4a6e164d6d346b3eb" alt=""
for_each算法
对容器中的元素进行依次操作
以一个for循环对每个元素进行第三个参数的操作
也可以使用c++11新形式range-based for statement
data:image/s3,"s3://crabby-images/a6b7a/a6b7a65f14b94d3fcc0b9ba5801910ceaaa08cdb" alt=""
replace、replace_if、replace_copy算法
取代算法,修改所有key value
条件取代算法,修改所有符合判定式子的value
拷贝取代算法,在新空间中拷贝元素,修改新空间所有key value
data:image/s3,"s3://crabby-images/3cd80/3cd804e0855c44c288196b1c94fadf7dc68e1433" alt=""
count、count_if算法
计数算法,对范围内所有元素计数
条件计数算法,对范围内复合条件的元素计数
在有些容器中,存在成员函数count,这时候要使用自己的count而不能使用全局count
成员函数中没有count的容器才可以使用全局count
data:image/s3,"s3://crabby-images/27b45/27b458721738fbf537808c77a105253a93c5ff12" alt=""
find、find_if算法
查找算法,顺序查找算法
条件查找算法,附条件的顺序查找算法
在有些容器中,存在成员函数find,这时候要使用自己的find而不能使用全局find
成员函数中没有find的容器才可以使用全局find
data:image/s3,"s3://crabby-images/28d0d/28d0d8b6e2ec531d37ceeb29e2dc7983b06ce8c5" alt=""
sort算法
排序算法
在有些容器中,存在成员函数sort,这时候要使用自己的count而不能使用全局sort
成员函数中没有sort的容器才可以使用全局sort
data:image/s3,"s3://crabby-images/28dde/28dde65800f89f6a91743d0e0186347ce773b999" alt=""
reverse iterator
逆序迭代器,rbegin()和rend()
迭代器,逆向指向容器头尾
data:image/s3,"s3://crabby-images/a0008/a0008876d996c39160e4a570fd6e45d97d456d85" alt=""
binary search算法
二分查找算法
要先排序,再查找
data:image/s3,"s3://crabby-images/75c91/75c912b5989bc6e5815b83295d82fbd8e779d04a" alt=""
仿函数/函数对象
functors仿函数,六大部件中最简单的一种
当算法需要一些独特的准则时,需要一些特定的操作,这时候要用一般函数或者仿函数来实现
三大类
-算数类
-逻辑运算类
-相对关系类
仿函数要继承才能与STL符合
data:image/s3,"s3://crabby-images/cec80/cec80ca8b6e27d9fcaee9544243ef65f905ba870" alt=""
data:image/s3,"s3://crabby-images/ae9b7/ae9b7abf6beda0359dde20d6d23fbc1f2ecde6b0" alt=""
data:image/s3,"s3://crabby-images/44b3d/44b3de97629df1766f66fb4363fb9810166a3fc8" alt=""
data:image/s3,"s3://crabby-images/df285/df285be74834e8d4d7c9b7fcf1b076c8bb8b50f5" alt=""
存在多种Adapter
适配器,六大部件的最后一个
改造接口,不改变主要功能
以复合方式实现功能
data:image/s3,"s3://crabby-images/031d6/031d642257f08c7f11ca88e90d49b1769e14ff18" alt=""
data:image/s3,"s3://crabby-images/c405a/c405ad724b51326416341947a0fb079630678375" alt=""
Binder2nd
function adapter函数适配器
data:image/s3,"s3://crabby-images/669b3/669b30f5562513b7fa989ef41778798f253e4e56" alt=""
not1
data:image/s3,"s3://crabby-images/fb0cd/fb0cd6f13e927b4964400e62b592e78939106c81" alt=""
bind
data:image/s3,"s3://crabby-images/297bd/297bdbb67b64c6d21bdb7a51a10bf3e8a3c66748" alt=""
data:image/s3,"s3://crabby-images/ab66d/ab66d92c92c9b14fbec4afcb3f7c78653c843ab0" alt=""
reverse_iterator
data:image/s3,"s3://crabby-images/b8d7a/b8d7af53905bad2a46802fb2198d6e5a3a19b39c" alt=""
inserter
data:image/s3,"s3://crabby-images/aec8e/aec8ebc8888f99b669d2f5474cc22f9eeffe7443" alt=""
ostream_iterator
data:image/s3,"s3://crabby-images/f675b/f675bb521d1a892893c93c519406317d0294d9af" alt=""
istream_iterator
data:image/s3,"s3://crabby-images/32302/32302cdc0d09ea1e0a07e5a2c2f4d43dfd11d08a" alt=""
data:image/s3,"s3://crabby-images/bf73d/bf73db094556081463903e415c39d983b32562aa" alt=""
.
网友评论