C++的STL中accumulate函数的使用方法

C++的STL中accumulate函数的使用方法

目录

1.累加求和

2.自定义数据类型的处理

3.用法补充

前言:

accumulate定义在#include中,作用有两个,一个是累加求和,另一个是自定义类型数据的处理

1.累加求和 int sum = accumulate(vec.begin() , vec.end() , 42);

accumulate带有三个形参:头两个形参指定要累加的元素范围,第三个形参则是累加的初值。
accumulate函数将它的一个内部变量设置为指定的初始值,然后在此初值上累加输入范围内所有元素的值。accumulate算法返回累加的结果,其返回类型就是其第三个实参的类型。

可以使用accumulate把string型的vector容器中的元素连接起来:

string sum = accumulate(v.begin() , v.end() , string(" "));

这个函数调用的效果是:从空字符串开始,把vec里的每个元素连接成一个字符串。

2.自定义数据类型的处理

C++ STL中有一个通用的数值类型计算函数— accumulate(),可以用来直接计算数组或者容器中C++内置数据类型,

例如:

#include <numeric> int arr[]={10,20,30,40,50}; vector<int> va(&arr[0],&arr[5]); int sum=accumulate(va.begin(),va.end(),0);  //sum = 150

是对于自定义数据类型,我们就需要自己动手写一个回调函数来实现自定义数据的处理,然后让它作为accumulate()的第四个参数,accumulate()的原型为

template<class _InIt,     class _Ty,     class _Fn2> inline     _Ty _Accumulate(_InIt _First, _InIt _Last, _Ty _Val, _Fn2 _Func)     {    // return sum of _Val and all in [_First, _Last), using _Func     for (; _First != _Last; ++_First)         _Val = _Func(_Val, *_First);     return (_Val);     }

例如:

#include <vector> #include <string> using namespace std; struct Grade {     string name;     int grade; }; int main() {     Grade subject[3] = {         { "English", 80 },         { "Biology", 70 },         { "History", 90 }     };     int sum = accumulate(subject, subject + 3, 0, [](int a, Grade b){return a + b.grade; });//a值是前面计算的中间结果 看前面的原型模板定义~ a 就是 _Val     cout << sum << endl;     system("pause");     return 0; } 3.用法补充

我们在必要时可以定义自己的加法运算。

例如:

​​​​​​​std::vector<int> values {2, 0, 12, 3, 5, 0, 2, 7, 0, 8}; int min {3}; auto sum = std::accumulate(std::begin(values), std::end(values), 0, [min] (int sum, int v) {     if(v < min)         return sum;     return sum + v; }); std::cout << "The sum of the elements greater than " << min-1<<"is " << sum << std::endl;  // 35

这里忽略了值小于 3 的元素。这个条件可以尽可能复杂,因此,我们能够求出指定范围内的元素之和。这个运算并不一定要是加法,可以是任何不修改操作数或不使定义范围的迭代器无效的运算。例如,为数值元素定义的乘法运算函数会生成元素的乘积,只要初值为 1。实现浮点元素除法的函数会生成元素乘积的倒数,只要初值为 1。

下面展示了如何生成元素的乘积:

std::vector<int> values {2, 3, 5, 7, 11, 13}; auto product = std::accumulate(std::begin(values), std::end(values), 1, std::multiplies<int>()); // 30030

这里用来自于 functional 头文件的函数作为第 4 个参数。如果有值为 0 的元素,可以像上一个代码段中的 lambda 表达式那样忽略它们。

string 类支持加法,因此可以将 accumulate() 应用到 string 对象的序列上:

std:: vector<string> numbers {"one", "two", "three", "four", "five","six", "seven","eight", "nine","ten"}; auto s = std::accumulate(std::begin(numbers), std::end(numbers), string{},[](strings str, string& element) {     if (element[0] == 't')         return str +' '+ element;     return str; }); // Result: " two three ten"

这段代码连接了以开头的 string 对象,并用空格将它们隔开。

acumulate() 算法得到的结果可能和它所应用的序列中的元素类型不同:

std::vector<int> numbers {1, 2, 3, 10, 11, 12}; auto s = std::accumulate(std::begin(numbers), std::end(numbers),string {"The numbers are"},[](strings str, int n){ return str + " : " + std::to_string(n);}); std::cout << s << std::endl;//Output: The numbers are: 1: 2: 3: 10: 11: 12

lambda 表达式使用的 to_string() 函数会返回一个数值参数的 string 形式,所以应用 accumulate() 到这里的整数序列会返回注释中显示的 string。

到此这篇关于C++的STL中accumulate函数的使用方法的文章就介绍到这了,更多相关C++的STL中accumulate内容请搜索易知道(ezd.cc)以前的文章或继续浏览下面的相关文章希望大家以后多多支持易知道(ezd.cc)!

推荐阅读

    excel怎么用乘法函数

    excel怎么用乘法函数,乘法,函数,哪个,excel乘法函数怎么用?1、首先用鼠标选中要计算的单元格。2、然后选中单元格后点击左上方工具栏的fx公

    无法读取U盘中的数据

    无法读取U盘中的数据,,核心提示:我有一个512MB的U盘,把它插在电脑显示器里面是空的,但右键单击以查看已经使用USB 480mb文件的属性未设置为隐

    excel中乘法函数是什么?

    excel中乘法函数是什么?,乘法,函数,什么,打开表格,在C1单元格中输入“=A1*B1”乘法公式。以此类推到多个单元。1、A1*B1=C1的Excel乘法公式

    标准差excel用什么函数?

    标准差excel用什么函数?,函数,标准,什么,在数据单元格的下方输入l标准差公式函数公式“=STDEVPA(C2:C6)”。按下回车,求出标准公差值。详细

    EXCEL数据透视表怎么用?是干什么的

    EXCEL数据透视表怎么用?是干什么的,透视,干什么,怎么,excel透视表:数据透视表(Pivot Table)是一种交互式的表,可以进行某些计算,如求和与计数等

    通过备份记录获得数据库的增长

    通过备份记录获得数据库的增长,,通常你想知道数据库是否正在增长,以及它增长了多少,可能比较数据库中每个历史时期的大小。 但是我们怎样才