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>?
基础教程推荐
- 管理共享内存应该分配多少内存?(助推) 2022-12-07
- Windows Media Foundation 录制音频 2021-01-01
- 从 std::cin 读取密码 2021-01-01
- 如何“在 Finder 中显示"或“在资源管理器中显 2021-01-01
- 为 C/C++ 中的项目的 makefile 生成依赖项 2022-01-01
- 在 C++ 中循环遍历所有 Lua 全局变量 2021-01-01
- 如何使图像调整大小以在 Qt 中缩放? 2021-01-01
- 为什么语句不能出现在命名空间范围内? 2021-01-01
- 使用从字符串中提取的参数调用函数 2022-01-01
- 如何在不破坏 vtbl 的情况下做相当于 memset(this, ...) 的操作? 2022-01-01