Why is the std::accumulate function showing the wrong sum of a vectorlt;doublegt;?(为什么 std::accumulate 函数会显示向量的错误总和lt;doublegt;?)
问题描述
考虑以下代码来添加 vector
的所有元素:
Consider the following code for adding all the elements of a vector
:
#include<iostream>
#include<algorithm>
#include<numeric>
#include<vector>
using namespace std;
int main(void)
{
std::vector<double> V;
V.push_back(1.2);
V.push_back(3.6);
V.push_back(5.6);
double sum = accumulate(V.begin(),V.end(),0);
cout << "The sum of the elements of the vector V is " << sum << endl;
return 0;
}
当我在 Windows 上的 Cygwin 上编译并运行它时,我在终端得到输出
When I compile this on Cygwin on Windows and run it, I get the output at the terminal as
向量V的元素之和为9
accumulate
函数似乎将所有数字四舍五入并将它们相加,这将解释答案.
The accumulate
function seems to be rounding down all the numbers and adding them up, which would explain the answer.
这是 Cygwin g++ 编译器有问题,还是我对 accumulate
函数的错误解释,用于将 double
的vector
相加?
Is this something wrong with the Cygwin g++ compiler, or my misinterpretation of the accumulate
function for adding up a vector
of double
s?
推荐答案
std::accumulate
声明如下:
template <typename InputIt, typename T>
T accumulate(InputIt first, InputIt last, T init);
std::accumulate
的第二个模板参数被推导出为 int
因为 0
是 int
类型.改为传递双精度值,例如 0.0
.
The second template argument to std::accumulate
is deduced as int
because 0
is of type int
. Pass a double instead, like 0.0
.
这篇关于为什么 std::accumulate 函数会显示向量的错误总和<double>?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:为什么 std::accumulate 函数会显示向量的错误总和<double>?


- 从python回调到c++的选项 2022-11-16
- 一起使用 MPI 和 OpenCV 时出现分段错误 2022-01-01
- 使用/clr 时出现 LNK2022 错误 2022-01-01
- 近似搜索的工作原理 2021-01-01
- STL 中有 dereference_iterator 吗? 2022-01-01
- Stroustrup 的 Simple_window.h 2022-01-01
- C++ 协变模板 2021-01-01
- 如何对自定义类的向量使用std::find()? 2022-11-07
- 与 int by int 相比,为什么执行 float by float 矩阵乘法更快? 2021-01-01
- 静态初始化顺序失败 2022-01-01