第九层(11):STL之常用遍历算法

简介: 第九层(11):STL之常用遍历算法

前情回顾


在上一块石碑中,我学到了函数对象,同时下一块石碑也显露出来…


🚄上章地址:第九层(10):STL之函数对象


常用算法


算法主要是由头文件:

#include<algorithm>
#include<functional>
#include<numeric>


其中algorithm是最大的一个头文件,它其中包含是比较,交换,查找,遍历,复制等等,functional就是内建函数对象,numeric体积很小,其中有一些简单的数学运算的模板函数


常用遍历算法


常用的遍历算法有两种:

for_each//遍历容器
transform//搬运容器到另一个容器


for_each


for_each(beg,end,_func)


beg指的是开始迭代器,从哪里去遍历,end指结束迭代器,到哪里结束,_func表示一个函数,是在遍历的时候进行的操作,例如打印,可以用函数对象

使用:


#include<iostream>
using namespace std;
#include<algorithm>
#include<vector>
void print(int a)
{
  cout << a << " ";
}
void test1()
{
  vector<int> v;
  for (int i = 0; i < 10; ++i)
  {
  v.push_back(i);
  }
  for_each(v.begin(), v.end(), print);
  cout << endl;
}
int main()
{
  test1();
  return 0;
}


transform


transform(beg1,end1,beg2, _func)


beg1是原容器的其实迭代器,end1是的结束迭代器,beg2是目标容器的开始迭代器,_func在这里为函数或者函数对象,可以在搬运途中对搬运的元素进行操作,比如加多少减多少,这里有一个需要注意的地方,目标i容器要记得提前开辟好容器空间,保证能放下原容器的元素

使用:


#include<iostream>
using namespace std;
#include<algorithm>
#include<vector>
int add(int a)//对拷贝过来的数进行加一百的操作
{
  return a += 100;
}
void print(int a)
{
  cout << a << " ";
}
void test1()
{
  vector<int> v;
  for (int i = 0; i < 10; ++i)
  {
  v.push_back(i);
  }
  for_each(v. begin(), v.end(), print);
  cout << endl;
  vector<int> v1;
  v1.resize(v.size());//保证可以放下原容器
  transform(v.begin(), v.end(), v1.begin(), add);
  for_each(v1.begin(), v1.end(), print);
  cout << endl;
}
int main()
{
  test1();
  return 0;
}

0eacb84100b54626af849e6b562bf92a.png


下一座石碑


这座石碑倒下了,露出了下一座石碑…


😘预知后事如何,关注新专栏,和我一起征服C++这座巨塔

🚀专栏:C++爬塔日记

🙉都看到这里了,留下你们的👍点赞+⭐收藏+📋评论吧🙉


相关文章
|
4月前
|
存储 算法 Java
Java中,树与图的算法涉及二叉树的前序、中序、后序遍历以及DFS和BFS搜索。
【6月更文挑战第21天】Java中,树与图的算法涉及二叉树的前序、中序、后序遍历以及DFS和BFS搜索。二叉树遍历通过访问根、左、右子节点实现。DFS采用递归遍历图的节点,而BFS利用队列按层次访问。以下是简化的代码片段:[Java代码略]
40 4
|
2月前
|
存储 算法 Java
LeetCode经典算法题:二叉树遍历(递归遍历+迭代遍历+层序遍历)以及线索二叉树java详解
LeetCode经典算法题:二叉树遍历(递归遍历+迭代遍历+层序遍历)以及线索二叉树java详解
66 0
|
3月前
|
存储 算法 Python
“解锁Python高级数据结构新姿势:图的表示与遍历,让你的算法思维跃升新高度
【7月更文挑战第13天】Python中的图数据结构用于表示复杂关系,通过节点和边连接。常见的表示方法是邻接矩阵(适合稠密图)和邻接表(适合稀疏图)。图遍历包括DFS(深度优先搜索)和BFS(广度优先搜索):DFS深入探索分支,BFS逐层访问邻居。掌握这些技巧对优化算法和解决实际问题至关重要。**
30 1
|
3月前
|
算法 JavaScript
JS 【详解】树的遍历(含深度优先遍历和广度优先遍历的算法实现)
JS 【详解】树的遍历(含深度优先遍历和广度优先遍历的算法实现)
58 0
JS 【详解】树的遍历(含深度优先遍历和广度优先遍历的算法实现)
|
3月前
|
存储 算法 搜索推荐
|
3月前
|
算法 JavaScript
JS 【详解】二叉树(含二叉树的前、中、后序遍历技巧和算法实现)
JS 【详解】二叉树(含二叉树的前、中、后序遍历技巧和算法实现)
37 0
|
3月前
|
算法 C++
STL算法大全
以上只是一部分STL算法的简单概述,每一个算法都有其特定的使用场景和规则,具体使用时需要参考相关文档或者教程进行深入理解和学习。
28 0
|
4月前
|
算法 搜索推荐 C++
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
|
2天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于GA遗传优化的GroupCNN分组卷积网络时间序列预测算法matlab仿真
该算法结合了遗传算法(GA)与分组卷积神经网络(GroupCNN),利用GA优化GroupCNN的网络结构和超参数,提升时间序列预测精度与效率。遗传算法通过模拟自然选择过程中的选择、交叉和变异操作寻找最优解;分组卷积则有效减少了计算成本和参数数量。本项目使用MATLAB2022A实现,并提供完整代码及视频教程。注意:展示图含水印,完整程序运行无水印。
|
1天前
|
算法 决策智能
基于禁忌搜索算法的VRP问题求解matlab仿真,带GUI界面,可设置参数
该程序基于禁忌搜索算法求解车辆路径问题(VRP),使用MATLAB2022a版本实现,并带有GUI界面。用户可通过界面设置参数并查看结果。禁忌搜索算法通过迭代改进当前解,并利用记忆机制避免陷入局部最优。程序包含初始化、定义邻域结构、设置禁忌列表等步骤,最终输出最优路径和相关数据图表。