#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include <algorithm>
#include <vector>
#include <functional>
using namespace std;/*
遍历算法 遍历容器元素
@param beg 开始迭代器
@param end 结束迭代器
@param _callback  函数回调或者函数对象
@return 函数对象
*///void myPrint(int v)
//{
//  cout << v << endl;
//}struct myPrint01
{void operator()(int v){cout << v << endl;}
};void test01()
{vector<int>v;for (int i = 0; i < 10; i++){v.push_back(i);}for_each(v.begin(), v.end(), myPrint01());
}struct myPrint02
{void operator()(int v){cout << v << endl;m_Count++;}int m_Count;
};
//2 for_each有返回值
void test02()
{vector<int>v;for (int i = 0; i < 10; i++){v.push_back(i);}myPrint02 print2 = for_each(v.begin(), v.end(), myPrint02());cout << print2.m_Count << endl;
}//3 for_each可以绑定参数进行输出
struct myPrint03 :public binary_function<int, int, void>
{void operator()(int v, int start) const{cout << v + start << endl;}
};void test03()
{vector<int>v;for (int i = 0; i < 10; i++){v.push_back(i);}for_each(v.begin(), v.end(), bind2nd(myPrint03(), 10000));
}/*
transform算法 将指定容器区间元素搬运到另一容器中
注意 : transform 不会给目标容器分配内存,所以需要我们提前分配好内存
@param beg1 源容器开始迭代器
@param end1 源容器结束迭代器
@param beg2 目标容器开始迭代器
@param _cakkback 回调函数或者函数对象
@return 返回目标容器迭代器
*/class TransForm
{
public:int operator()(int val){return val + 10;}
};
void test04()
{vector<int>v; //原容器for (int i = 0; i < 10; i++){v.push_back(i);}vector<int>vTarget; //目标容器vTarget.resize(v.size());transform(v.begin(), v.end(), vTarget.begin(), TransForm());for_each(vTarget.begin(), vTarget.end(), [](int val) { cout << val << " "; });}//transform 第二种用法 将两个容器数据相加搬运到目标容器
class TransForm2
{
public:int operator()(int val, int val2){return val + val2;}
};void test05()
{vector<int>v1;vector<int>v2;for (int i = 0; i < 10; i++){v1.push_back(100 + i);v2.push_back(200 + i);}vector<int>vTarget; //目标容器vTarget.resize(v1.size());transform(v1.begin(), v1.end(), v2.begin(), vTarget.begin(), TransForm2());// 300 302...for_each(vTarget.begin(), vTarget.end(), [](int val) { cout << val << " "; });cout << "----" << endl;for (vector<int>::iterator it = v1.begin(); it != v1.end(); ++it) {cout << *it << endl;}
}int main() {//test01();//test02();//test03();//test04();test05();system("pause");return EXIT_SUCCESS;
}

C++ 常用算法之遍历相关推荐

  1. 数据分析与挖掘理论-常用算法对比(纯理论较枯燥)

    常见数据挖掘算法分析 概述 一般认为,数据挖掘领域所使用的方法均属于机器学习算法.深度学习算法和数据挖掘算法. 一般认为,数据挖掘领域的问题主要有分类.回归.聚类.推荐.图像识别.预测. 一般认为,数 ...

  2. php面试带项目_PHP面试常用算法(推荐)

    一.冒泡排序 基本思想: 对需要排序的数组从后往前(逆序)进行多遍的扫描,当发现相邻的两个数值的次序与排序要求的规则不一致时,就将这两个数值进行交换.这样比较小(大)的数值就将逐渐从后面向前面移动. ...

  3. C++(8)--数组及常用算法

    数组及常用算法 1.数组基本概念 2.一维数组 2.1数组的定义 2.2数组初始化 2.3一维数组动态赋初值 2.4一维数组应用实例 2.5一维数组的排序算法 2.6 一维数组元素的删除和插入 arr ...

  4. C++超详细STL常用算法总结

    STL 常用算法: 写在开篇:整理了一些stl中很常用的算法,涉及到比较,交换,查找,遍历,复制,修改等.值得大嘎收藏呀!! 目录: STL 常用算法: 1. 常用遍历算法: 1.1 for_each ...

  5. java语言实现常用算法(排序和查找)

    以下是java语言实现的常用算法. 1.冒泡排序 /** 冒泡排序* * 有1至N个数* 第一轮比较N个数,第二轮比较N-1个数,...* 每一轮根据前面一个数和后面一个数比较,如果前者大于后者,交换 ...

  6. html5 游戏 算法,JS/HTML5游戏常用算法之碰撞检测 包围盒检测算法详解【圆形情况】...

    JS/HTML5游戏常用算法之碰撞检测 包围盒检测算法详解[圆形情况] 发布时间:2020-10-10 13:42:43 来源:脚本之家 阅读:95 作者:krapnik 本文实例讲述了JS/HTML ...

  7. (转)五大常用算法:分治、动态规划、贪心、回溯和分支界定

    分治算法 一.基本概念 在计算机科学中,分治法是一种很重要的算法.字面上的解释是"分而治之",就是把一个复杂的问题分成两个或更多的相同或相似的子问题,再把子问题分成更小的子问题-- ...

  8. etc的常见算法_几个常用算法的适应场景及其优缺点(非常好)

    本文主要回顾下几个常用算法的适应场景及其优缺点! 机器学习算法太多了,分类.回归.聚类.推荐.图像识别领域等等,要想找到一个合适算法真的不容易,所以在实际应用中,我们一般都是采用启发式学习方式来实验. ...

  9. morris算法(莫里斯遍历) [数据结构与算法]

    morris算法(莫里斯算法) Morris算法, 我们最常用于解决二叉树的遍历问题, 以及与遍历相关的一些问题(其实在二叉树系列问题中, 我们解决各种问题的时候都要涉及到一个对二叉树的遍历) 我们先 ...

最新文章

  1. CCF-CSP 201612-2 工资计算(C++满分代码)
  2. 解决Eclipse、Android Studio ADT AVD不能检测到手机
  3. MyBatis 解决了什么问题?
  4. Adler-32校验算法
  5. gulp中使用babel-polyfill编译es6拓展语法
  6. Struts2中的OGNL详解
  7. Redis缓存雪崩、缓存穿透、热点Key
  8. (计算机组成原理)第二章数据的表示和运算-第二节3:定点数的移位运算(算数移位、逻辑移位和循环移位)
  9. php字符集转换,php字符集转换
  10. C# 处理excel 大全
  11. Swift iOS : plist
  12. android java程序中调用shell命令
  13. 高德地图android显示级别指定位置,获取地图中心点/级别
  14. 第7讲 视觉里程计1 下篇
  15. 基础算法:斐波那契函数学习
  16. python中rgb颜色_自定义RGB颜色与Python诅咒
  17. 【台大郭彦甫】Matlab入门教程超详细学习笔记七:数值微积分(附PPT链接)
  18. 数字化转型的三个重点方向
  19. MySQL日期转换为空问题
  20. 马化腾2018中国“互联网+”数字经济峰会演讲《互联网+助力数字中国建设》全文...

热门文章

  1. 《精通Spring 4.x 企业应用开发实战》学习笔记
  2. django QuerySet对象转换成字典对象
  3. excel数据生成sql insert语句
  4. 【转】phpize学习
  5. C语言操作mysql
  6. C# char[]与string之间的相互转换
  7. [LeetCode]Find Minimum in Rotated Sorted Array
  8. ADO.NET中在C/S模式中使用的连接池
  9. php职业认证,如何用 PHP 进行 HTTP 认证
  10. linux中查看相关日志记录,linux重启查看日志及历史记录 查询原因