C++的STL中accumulate的用法

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

1.累加求和

  1. int sum = accumulate(vec.begin() , vec.end() , 42);  
int sum = accumulate(vec.begin() , vec.end() , 42);

accumulate带有三个形参:头两个形参指定要累加的元素范围,第三个形参则是累加的初值。

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

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

  1. string sum = accumulate(v.begin() , v.end() , string(" "));  
string sum = accumulate(v.begin() , v.end() , string(" "));
这个函数调用的效果是:从空字符串开始,把vec里的每个元素连接成一个字符串。

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

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

  1. #include <numeric>  
  2. int arr[]={10,20,30,40,50};  
  3. vector<int> va(&arr[0],&arr[5]);  
  4. int sum=accumulate(va.begin(),va.end(),0);  //sum = 150  
#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()的原型为

  1. template<class _InIt,  
  2.     class _Ty,  
  3.     class _Fn2> inline  
  4.     _Ty _Accumulate(_InIt _First, _InIt _Last, _Ty _Val, _Fn2 _Func)  
  5.     {   // return sum of _Val and all in [_First, _Last), using _Func  
  6.     for (; _First != _Last; ++_First)  
  7.         _Val = _Func(_Val, *_First);  
  8.     return (_Val);  
  9.     }  
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);
	}
【例1】

  1. #include <vector>  
  2. #include <string>  
  3. using namespace std;  
  4.   
  5. struct Grade  
  6. {  
  7.     string name;  
  8.     int grade;  
  9. };  
  10.   
  11. int main()  
  12. {  
  13.     Grade subject[3] = {  
  14.         { "English", 80 },  
  15.         { "Biology", 70 },  
  16.         { "History", 90 }  
  17.     };  
  18.   
  19.     int sum = accumulate(subject, subject + 3, 0, [](int a, Grade b){return a + b.grade; });  
  20.     cout << sum << endl;  
  21.   
  22.     system("pause");  
  23.     return 0;  
  24. }  
#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; });
	cout << sum << endl;

	system("pause");
	return 0;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值