我一直无法找到从 C++ 中的整数向量中获取平均值的方法。
我不可能开始添加所有值,因为我可能会超过接受的最大整数值。
我怎样才能有效和快速地计算这个? C++ 语言中是否有任何标准库可以做到这一点?
原文由 dimitris93 发布,翻译遵循 CC BY-SA 4.0 许可协议
我一直无法找到从 C++ 中的整数向量中获取平均值的方法。
我不可能开始添加所有值,因为我可能会超过接受的最大整数值。
我怎样才能有效和快速地计算这个? C++ 语言中是否有任何标准库可以做到这一点?
原文由 dimitris93 发布,翻译遵循 CC BY-SA 4.0 许可协议
3 回答2k 阅读✓ 已解决
2 回答3.9k 阅读✓ 已解决
2 回答3.2k 阅读✓ 已解决
1 回答3.2k 阅读✓ 已解决
1 回答2.7k 阅读✓ 已解决
3 回答3.5k 阅读
3 回答485 阅读✓ 已解决
首选方法只是将足够宽的整数类型与
std::accumulate
:如果 这个总和溢出(有 2300 万个整数,平均值必须至少为 4.01x10 11 - 也就是说,它不会溢出,因为它甚至不适合
int32_t
.. . 所以你很好,但是如果你得到几个数量级的数字,或者有更宽的int
类型),那么你可以改用常见的“在线”算法来计算意思是:这不会溢出,不太容易损失精度,但由于重复的额外除法可能会更昂贵。