STL- 常用算法
概述:
-
算法主要是由头文件
<algorithm>
<functional>
<numeric>
组成。
-
<algorithm>
是所有STL头文件中最大的一个,范围涉及到比较、 交换、查找、遍历操作、复制、修改等等 -
<numeric>
体积很小,只包括几个在序列上面进行简单数学运算的模板函数 -
<functional>
定义了一些模板类,用以声明函数对象。
5.1 常用遍历算法
学习目标:
-
掌握常用的遍历算法
算法简介:
-
for_each
//遍历容器 -
transform
//搬运容器到另一个容器中
5.1.1 for_each
功能描述:
-
实现遍历容器
函数原型:
-
for_each(iterator beg, iterator end, _func);
// 遍历算法 遍历容器元素
// beg 开始迭代器
// end 结束迭代器
// _func 函数或者函数对象
示例:
总结:for_each在实际开发中是最常用遍历算法,需要熟练掌握
5.1.2 transform
功能描述:
-
搬运容器到另一个容器中
函数原型:
-
transform(iterator beg1, iterator end1, iterator beg2, _func);
//end1 源容器结束迭代器
//beg2 目标容器开始迭代器
//_func 函数或者函数对象
示例:
总结: 搬运的目标容器必须要提前开辟空间,否则无法正常搬运
5.2 常用查找算法
学习目标:
-
掌握常用的查找算法
算法简介:
-
find
//查找元素 -
find_if
//按条件查找元素 -
adjacent_find
//查找相邻重复元素 -
binary_search
//二分查找法 -
count
//统计元素个数 -
count_if
//按条件统计元素个数
5.2.1 find
功能描述:
-
查找指定元素,找到返回指定元素的迭代器,找不到返回结束迭代器end()
函数原型:
-
find(iterator beg, iterator end, value);
// 按值查找元素,找到返回指定位置迭代器,找不到返回结束迭代器位置
// beg 开始迭代器
// end 结束迭代器
// value 查找的元素
示例: