持续创作,加速成长!这是我参与「掘金日新计划 · 10 月更文挑战」的第24天,点击查看活动详情
5 STL- 常用算法
概述:
-
算法主要是由头文件
<algorithm><functional><numeric>组成。 -
<algorithm>是所有STL头文件中最大的一个,范围涉及到比较、 交换、查找、遍历操作、复制、修改等等 -
<numeric>体积很小,只包括几个在序列上面进行简单数学运算的模板函数 -
<functional>定义了一些模板类,用以声明函数对象。
1.1 常用遍历算法
学习目标:
- 掌握常用的遍历算法
算法简介:
for_each//遍历容器transform//搬运容器到另一个容器中
1.2 for_each
功能描述:
- 实现遍历容器
函数原型:
-
for_each(iterator beg, iterator end, _func);// 遍历算法 遍历容器元素
// beg 开始迭代器
// end 结束迭代器
// _func 函数或者函数对象
1.3 代码示例:
#include <algorithm>
#include <vector>
//普通函数
void print01(int val)
{
cout << val << " ";
}
//函数对象
class print02
{
public:
void operator()(int val)
{
cout << val << " ";
}
};
//for_each算法基本用法
void test01() {
vector<int> v;
for (int i = 0; i < 10; i++)
{
v.push_back(i);
}
//遍历算法
for_each(v.begin(), v.end(), print01);
cout << endl;
for_each(v.begin(), v.end(), print02());
cout << endl;
}
int main() {
test01();
system("pause");
return 0;
}
1.4 **总结:**for_each在实际开发中是最常用遍历算法,需要熟练掌握
1.5 STL算法补充说明
STL算法部分主要由头文件,,组成。 STL中算法大致分为四类:
* 1、非可变序列算法:指不直接修改其所操作的容器内容的算法。
* 2、可变序列算法:指可以修改它们所操作的容器内容的算法。
*3、排序算法:包括对序列进行排序和合并的算法、搜索算法以及有序序列上的集合操作。
* 4、数值算法:对容器内容进行数值计算。
以下对所有算法进行细致分类并标明功能:
- 1.1 查找算法(13个):判断容器中是否包含某个值
adjacent_find:在iterator对标识元素范围内,查找一对相邻重复元素,找到则返回指向这对元素的第一个元素的ForwardIterator。否则返回last。重载版本使用输入的二元操作符代替相等的判断。
binary_search:在有序序列中查找value,找到返回true。重载的版本实用指定的比较函数对象或函数指针来判断相等。
count_if: 利用输入的操作符,对标志范围内的元素进行操作,返回结果为true的个数。