C++泛型算法中的accumulate

原创 2015年11月20日 11:41:11

一些算法只会读取其输入范围内的元素,而从不改变元素。accumulate算法就是属于这种只读算法。它定义在头文件numeric中。accumulate函数接受三个参数,前两个指出了需要求和的元素的范围,第三个参数是和的初始值。假定vec是一个整数序列,则:

int sum=accumulate(vec.cbegin(),vec.cend(),0);

这条语句将sum设置为vec中元素的和,和的初始值为0,我们来写个程序验证一下:

#include<iostream>
#include<vector>
#include<numeric>
using namespace std;
int main()
{
	vector<int>v;
	int temp;
	while (cin >> temp)
	{
		v.push_back(temp);
	}
	int sum = accumulate(v.cbegin(), v.cend(), 0);
	cout << sum << endl;
	system("pause");
	return 0;
}
我们来看下结果:


我们向vector中输入1,2,3,4,5,运行的结果是15.

accumulate将第三个参数作为求和起点,这蕴含着一个编程假定:将元素类型加到和的类型上的操作必须是可行的。即:序列中的类型必须与第三个采纳数匹配,或者能够进行转换为第三个参数的类型。









版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

C++ STL算法之accumulate函数

1. 介绍  用来计算特定范围内(包括连续的部分和初始值)所有元素的和,除此之外,还可以用指定的二进制操作来计算特定范围内的元素结果。其头文件在numeric中。   accumulate原函数声明...

C++语法基础--泛型算法(generic algorithm)--只读算法accumulate(),find_first_of(),count(),count_if()

注:泛型算法实在太多,太繁杂,全都掌握也不现实,也没有必要。所以暂时只研究一些常用的算法。  1.只读算法   *accumulate(在numeric头文件中定义)    Computes th...

c++ primer 泛型算法 经典

[C++ 面试基础知识总结] 泛型算法

[C++ 面试基础知识总结] 泛型算法 参考书籍:《C++ Primer》 目录 C 面试基础知识总结 泛型算法 目录 基础泛型算法 只读算法 写容器算法 重排容器元素算法 定制操作 向...

C++ primer 十九 泛型算法replace/replace_copy/sort/unique

replace算法读入一个序列,并将其中所有等于给定值的元素都改为另一个 值。此算法接受4个参数:前两个是迭代器,表示输入序列,后两个一个是要搜索的值, 另一个是新值。它将所有等亍第一个值的元素替换为...

c++ algorithm 泛型算法的方法实现原型

// algorithm standard header #pragma once #ifndef _ALGORITHM_ #define _ALGORITHM_ #ifndef RC_INV...

c++ 泛型算法

1:c++的算法库中有超过100个算法,这些算法均不会直接操作底层的元素,他们是通过操作迭代器规定的范围来实现的。3:只读算法,操作两个序列的算法,写容器的算法,插入迭代器,拷贝算法(1):只读算法如...

C++标准泛型算法库的函数为什么设计成不能改变容器大小?

C++标准泛型算法库的函数为什么设计成不能改变容器大小? 以及为什么back_inserter这样的函数能在不违反“不改变容器大小”的规范上在容器尾添加元素?

C++ 对bitset使用泛型算法

泛型算法是C++的一大特色,而bitset
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)